# Interface

# 

# 特集

0 0 3

高速ロジックインターフェースからPCI Express, 10Gigabit Ethernetまで

# 43 高速バスシステムの徹底研究

A complete study of the high speed bus system

プロローグ

44 高速バスいろいろ ―― デバイス間データ転送からボード間/筐体間通信まで

桑野雅彦

Prologue Various high speed devices From data transfer between-devices to between-boards/between-bodies communication Masahiko Kuwano

第1章 LVTTL/SSTL/HSTLなどのシングルエンドから、LVDSなどのディファレンシャルまで

46 高速ロジック回路の電気的仕様いろいろ

# 食将宝

Chapter 1 Various electric specifications of high speed logic circuits Masami Ikura

第2章 3.35Gbps×12チャネルで最大40Gbpsの転送にも対応する

66 パラレル光モジュールによるデバイス間/ボード間通信の現状

小林雄袜

Chapter 2 Present situation of between-devices/between-boards communications with parallel optical module Yusuke Kobayashi

第3章 元祖PC/ATからHubInterface, HyperTransportまで

72 PC/AT互換機チップセットのデータ転送

叒野雅彦

Chapter 3 Data transfer of the PC/AT compatible chip set Masahiko Kuwano

第4章 今後の高速拡張バスのスタンダード

80 PCI Express規格の概要

里見尚志

Chapter 4 Summary of PCI Express standard Hisashi Satomi

第5章 バスアナライザを使って実際のバスの動作を見る

93 PCI-Xの特徴とプロトコル

村井康秀

Chapter 5 Characteristics of PCI-X and its protocol Yasuhide Murai

第6章 PC周辺機器をより高速に接続するための

101 USBハイスピード伝送の実現

2野雅彦

Chapter 6 Realization of high speed transfer in USB Masahiko Kuwano

**Appendix** 

106 IEEE1394.b最新動向

Appendix Present situations of IEEE1394.b
Hiroyuki Kitayama

第7章 ブロードバンドの高速化でバックボーンもより高速に

110 10Gigabit Ethernetの技術動向

公本信幸

Chapter 7 Technology trends of 10Gigabit Ethernet Nobuyuki Matsumoto





# Interface

Shigehisa Yamamoto

山本繁寿

山中 勝 Masaru Yamanaka

川口幸裕

岸 哲夫

Tetsuo Kishi

Yukihiro Kawaguchi

#### 話題のテクノロジ解説

144

XScaleプロセッサ徹底活用研究(第2回) 121 XScaleプロセッサのプログラミング

Programming of XScale processor

組み込みLinuxをとりまく世界(第1回)

組み込みLinuxの長所短所とスマートな導入のための要素 Advantages and disadvantages of embedded Linux and elements for a smart introduction 130

Webサーバ機能をもつEthernet-シリアルコンバータ「XPort」活用技法(後編)

Javaアプレットによるシリアル機器の制御 Serial device control with Java applets

音楽配信技術の最新動向(第5回)

ピアツーピアを利用した配信とOggVorbisのエンコード

Distribution using peer-to-peer and encoding of OggVorbis

家電機器をネットワーク化するアーキテクチャUniversal Plug and Playの全貌(第2回)

UPnPの規格概要 (後編) 164

Outline of UPnP (Part 2)

PC/ATのさまざまな資源を管理する

ACPIによるPC/ATの電力管理とコンフィグレーション(前編)

Power management of PC/AT with ACPI and its configuration

安達健一 Kenichi Adachi

北村俊之

広畑由紀夫 Yukio Hirohata

山本 強 Tsuyoshi Yamamoto

祐安重夫 Shigeo Sukeyasu

旭 征佑

宮坂電人

Dento Miyasaka

Shousuke Asahi

H.Tony Chin

Toshiyuki Kitamura

本間 康

Yasushi Chama

#### ショウレポート&コラム

先端要素技術の総合展示会

13 **TECHNO-FRONTIER 2003** 

TECHNO-FRONTIER 2003

ハッカーの常識的見聞録(第31回)

17 Windows Serever 2003製品版がやってきた!

Windows Serever 2003 products have arrived!

移り気な情報工学(第33回)

ロゼッタストーンとWWW Rosetta stone and WWW 19

IPパケットの隙間から(第57回)

129 言論の不自由とサポート環境の不自由

Restriction of speech and support environment

シニアエンジニアの技術草子(弐拾九之段)

190 神への冒涜

Descreation for God

Engineering Life in Silicon Valley (対談編)

ビジネススキルを修行しながらエンジニアを続ける

Train oneself of business skills while continuing as an engineer

#### 般解説&連載

プログラミングの要(第4回)

115 ハリウッドの法則

A Law of Hollywood

ファイアウォール、帯域管理装置などのプラットホームとなる

134 アプライアンス機器 [InterWay/GB] の概要

Summary of an appliance device, "InterWay/GB

開発環境探訪(第20回)

オブジェクト指向を採用したスクリプト言語——Scriptol A script language supporting the object oriented system — Scriptol 138

開発技術者のためのアセンブラ入門(第19回)

154 制御転送命令

Control transfer instruction

青木 弘/新井雅樹/遠藤俊也/鈴木明彦/中井清元 Hiroshi Aoki/Masaki Arai/Toshiya Endo/Akihiko Suzuki/Kiyomoto Naka

> 水野貴明 Takaaki Mizuno

大貫広幸 Hiroyuki oonuki

#### ■情報のページ ……………

- **Show & News Digest**
- **NEW PRODUCTS** 194
- 200 海外・国内イベント/セミナー情報
- 201 読者の広場

202 次号のお知らせ 連載「フリーソフトウェア徹底活用講座」、「やり直しのための信号数学」は、 お休みさせていただきます。

Interface July 2003

7

(写真 4) コンテックのフ ロントメンテナ ンス ATX シャー シ MPC シリーズ



# TECHNO-FRONTIER 2003

#### 北村俊之

「次の時代が見えてくる」をキーワードに、エレクトロニクス、メ カトロニクスの先端要素技術、製品を一堂に展示する「TECHNO-FRONTIER 2003」が4月16日(水)~18(金)の3日間、日本コン ベンションセンターで開催された. 主催は(社)日本能率協会. 本展 示会では「第21回 モータ技術展」、「第18回 電源システム展」、「第 16回 EMC · ノイズ対策技術展」,「第12回 モーション・エンジニ アリング展」、「第12回 ボード・コンピュータ展」、「第5回 熱対策 技術展1. 「第4回 高効率・省エネ促進技術展1. 「第3回 カーエレク トロニクスデバイス展1、「第3回 Bluetooth Expolの九つの展示会 と関連の七つのシンポジウムが同時に開催された. また, 特別企画 として「開発・設計を支援する解析技術」、「リニアモータと応用技術」、 「産・学技術移転 (TLO) 交流プラザ」, 関連企画として「海外部品調達 展 2003」も併せて開催されるなど、大規模な展示会となっていた. 最終的な来場者数は、3日間で122.940人だった、今回は、「第12 回 ボード・コンピュータ展」および「第3回 Bluetooth Expo」を中 心にレポートする.

#### 第12回ボード・コンピュータ展

ボード・コンピュータ展は、組み込み機器、システムの最適構築を支援する各種バスボードからソフトウェア、開発支援ツール、周辺機器の実用技術の展示会となっている.

アドバネットは、コンパクト PCIバス、VMEバス、PCIバス、PMC、StarFabric ブリッジボードなど、多様な規格に対応したボードを多数展示していた。なかでも今回注目を集めていたのが、Mobile Pentium4-M を搭載したコンパクト PCI



〔写真 1〕アドバネット の A6pci8012

バス対応の CPU ボード 「A6pci8012」(**写真 1**). こちらは次世代産業機器に欠かせない CPU パワーを提供する製品であるという。また、同ブースでは StarFabric ブリッジボートの各種新製品も展示されており、こちらも最近注目を集めているとのことだった。

この StarFabric 規格を積極的に紹介したロッキーは、StarGate



〔写真 2〕ロッキーの Star Gate コンパク ト PCI ボード



〔写真 3〕ソリトンシステ ムズの SCI ネッ トワークカード

コンパクト PCI ボードの新製品を展示していた (写真 2). 同製品は 2 ポートのバンドリングにより, 同時に送受信5Gbps を実現している. また従来のBIOS や OS の PCI ソフトウェアと完全互換であるため, PCI バス拡張 (64 ビット/66MHz) やマルチプロセッサシステムを容易に構築できるという.

ソリトンシステムズでは、300Mバイト/秒のデータ転送が可能なSCIネットワークカード(写真3)、異なるバスをメモリイメージで直結するバスアダプタ、PCIバスを拡張するエキスパンション、汎用インターフェースとしてファイバチャネル、ギガビットEthernetカードな

どの展示が行われていた.

PCハードウェアの診断ツールを展示していたのは、ウルトラエックスである。同製品では独自のセルフブートテクノロジを用い、OSを必要とせずにパソコンの電源投入後、数秒で起動し診断できる機能をもっている。必要となるシステムはFD1枚に収まっており、「P.H.D PCI」ではブート不可能なパソコンでも強制的にブートをかけ、診断する機能をもっている。

コンテックでは、フロントメンテナンス ATX シャーシ 「MPC シリーズ」の展示を行っていた(写真 4). 同製品はスライドレールで主要部分を引き出して部品交換、ケーブル配線を全面に集中するなど完全フロントメンテナンスを実現している. また、オリジナル RAS ボードにより、WWW ブラウザで各種設定や電源のオン/オフなどの遠隔操作が行えることも特徴である.

ケーメックスでは組み込みシステムやロボティクスに最適なCPUボードの新製品「ICP-P4」の展示を行っていた。同製品はCPUにPentium4を採用し、ハイパフォーマンスなシステム開発を強力にサポートするという。また、マルチディスプレイに高速、同時配信を可能にする高速データ転送システム「GigaSTAR」(写真5)も注目度の高い製品とのことであった。



〔写真 5〕ケーメックス の GigaSTAR

昌新は、LANTRONIXの組み込み用シリアルデバイスサーバ「CoBox-Micro」の展示を行っていた(写真 6). サイズが40×49mmと小型であるため、ほとんどのシリアルデバイスに組み込むことが



〔写真 6〕LANTRONIX のシリアルデ バイスサーバ CoBox-Micro

可能で、Ethernet へ接続するための RJ-45 コネクタを装備している.

#### • 第 3 回 Bluetooth Expo

Bluetooth Expo は、Bluetooth の各種デバイス、測定機器、ソフトウェア、認証サービスからソリューションまでを幅広く展示しており、併設で「Bluetooth フォーラム」も開催された。

東陽テクニカでは、CATC 社の Bluetooth プロトコルアナライザ およびジェネレータが展示されていた. とくに新製品である 「BT Tracer/Trainer」は、前機種から大幅に機能拡張されたフラグシップ モデルであり、開発からテスト、評価までをカバーする統合開発環境を提供している. リアルタイムトレース機能、エラーパケット発生機能、HCI キャプチャモード機能が新たに追加されていることも大きな特徴である.

ネオテクノでは、Bluetooth 実装に必要なハードとソフトをコンパ



〔写真 7〕ネオテクノの BlueStick

クトにモジュール化した [BlueStick] が注目を集めていた (写真7). ベースバンドLSI, プロトコルスタック部分を 1 チップCPU にソフトウェアとして組み込むことで, 部品点数の削減, コストダウンを実現しているという.

**BlueStick** ルネサステクノロジ (日立製作所半導体 グループと三菱電機半導体が合併) では、Bluetooth ベースバンド機能搭載マイコン [SH7630]、Bluetooth ベースバンド LSI [M64110WG] および Bluetooth RF LSI [M64846FP] の展示と、これらを利用したソリューションのデモを行っていた。

# h o w & N e w s

#### 第2回UMLロボットコンテスト

■ 日時: 2003年4月16日(水)

■場所:青山TEPIA(東京都港区)

オブジェクトテクノロジー研究所(旧社名:OMGジャパン)の主催によ り、UMLに関するカンファレンスUML Forum 2003が開催され、その 中でUMLを用いた設計を競うロボットコンテストが開催された。競技内容 は、以下の2種類

ショート・トラック競技部門

黒い線に沿ってトラックを一周し、その時間を競う.

レスキュー部門

黒い線に沿って走ったあと、線のない区間を通り、グレースケール地帯、 もう一度黒い線を走ったあと、城のオブジェのボタンを押すことによりお 姫様と従者の人形を回収する"お姫様救出ゲーム"である。得点は時間およ び回収した人形の数により算出される。

完走率はショート部門で半数、レスキュー部門で3割程度であったが、 ショート部門の優勝者は20mのコースを22秒代で走り、「20秒を切るこ

とも夢ではない」という主催者側のコメントも聞かれる好結果となった。

また、会場の後方には各モデルのUML図が 展示され、その設計を知ることができた。と くに審査員特別賞を受賞したチーム" AFlend " は、その状態モデルの着眼点が評価された。 他のモデルは、マシンの状態を"直線モード or 曲線モード or 勾配モード "のようにorで 表現していたが、AFlendだけが状態を"直線 か否か and 勾配か否か "のようにandで表現 しており、複数の条件が関わる現実事象をう まくモデリングした例として高く評価されて





UMLロボットコンテス トのマスコット



コースのようす

#### Richard Stallman氏 特別議演会

- ■日時:2003年4月21日(月)
- ■場所:虎ノ門パストラル(東京都港区)

Emblix主催により、GNUプロジェクトの推進リーダーであるRichard Stallman氏の講演会が開催された.

会場ではStallman氏によりGNUプロジェクト成立の背景と活動の紹介、 GNU GPLの概念, LinuxはカーネルだけでなくGNUの成果物によりOS として成立していることから" GNU/Linux "と呼んでほしいとのことのほ

か、近年のソフトウェアに対する特許戦略 を挙げ、「すべてのプログラマに対し、特 許問題は大きな脅威になりうる」と警鐘を 鳴らした。また、「携帯電話などのソフト ウェアもGPLにすべきか?」という質問に 対し、「(ユーザーが)自由にソフトウェア を作成し、インストールすることができな い組み込み機器は、GNUプロジェクトの範 囲外ではないか」との意見が述べられた.



Richard Stallman Et.

#### グレープシステム 「ITRON入門と通信プロトコルセミナー

- ■日時: 2003年4月18日(金) ■場所: クイーンズタワーB (神奈川県横浜市)

(株) グレープシステムにより、ThreadX-μITRONとFusion通信プロ トコルスタック、Webプロダクトに関するセミナーが開催された。

ThreadX-µITRONは組み込み向けリアルタイムOSであるThreadX上 にμITRON互換レイヤを搭載したもので、これを題材にμITRONのタス ク管理機能,スケジューリング,同期通信,割り込み,OSコンフィギュレ ーションなど、 µITRONのプログラミングに関して留意すべき一般事項が わかりやすく解説された.

続く通信プロトコルスタックであるFusion NETは、TCP/IP、PPP、

SNMPなどのプロトコルスタックについて、その概要と移植の方法など を実際のコードを交えて解説した.

また、組み込み向けXMLツールキットFusion WEBについても取り上 げられた. なかでもFusion XMLマイクロパーサはANSI Cで書かれた

XMLパーサ、通常、この種類の ソフトはJavaやC++などで書か れているが、組み込み向けとい うこともありANSI Cを採用し、 ROM 13Kバイト, RAM 2Kバ イトで動作する小サイズが特徴 とのことだ. ほかにもXMLスキ ーマコンパイラ、SOAPプロト コルスタックなども紹介された.



セミナーのようす

#### Jaluna OSセミナー

- 日時:2003年4月11日(金) 場所:JAFCOホール(東京都千代田区)

昨年10月にJaluna社と業務提携したウェブソフト・インターナショナ ル(株)により、Jaluna OSに関するセミナーが開催された。

Jaluna OSはC5マイクロカーネル(Chorus OS Ver.5)をベースとし た分散リアルタイムOS. RT-POSIX APIをサポートし、カーネル本体の サイズは30Kバイト、システムを構築するうえでのトータルでの最小フッ トプリントは60Kバイト~. メモリマネージャやスケジューラなどはカー ネルの外部に位置する. サポートCPUはPowerPC/x86/SPARCで, MIPSやARMに関しては準備中とのことだ.

JalunaOSは任意のプロセスをユーザーモードおよびカーネルモードで 動作させることが可能という特徴をもつ、そのため、製品開発時にはユー ザーモードでデバッグを行い、出荷時にはカーネルモードで動作させ速度 を向上させることなどが可能だ.

JalunaOSはマイクロカーネルベースのOSをそのまま利用する Jaluna-1と、その上にLinuxエミュレーション環境を導入してLinuxのア プリケーションとリアルタイムOSの性能を同時に使用可能とする Jaluna-2の二つの利用形態が選択できるようになっている。また、 VxWorks Compatibility Kitも提供される.

Jaluna-1 Developers Editionはオープンソース, ロイヤリティフリー で提供され、SourceForgeでも公開されている(http://jaluna. sourceforge.net/).

# ハッカ。 常識的見聞録

31

#### 広畑由紀夫



★4月25日. ついに米国で Windows Server 2003 が発売されました。さらに米国では Visual Studio .NET 2003 も発売開始となり、いよいよサーバ製品から開発にいたるまで、.NET 製品が出そろったことになります。今回は、その進化のぐあいを見てみたいと思います。

#### • Windows Server 2003

2003年4月25日に発売開始されたバージョンは、米国内向けの英語版ですが、すでに日本語版も製造工程に入っており、正式な発売日程は発表されてはいないものの、早ければ本号が発売されるころには発売開始になっているかもしれません。さて、本当に長く待たされた Windows Server 2003ですが、製品版で筆者がとくに気に入った点を紹介します。

- 1) サーバモードの CPU リソース割り当てがさらに重視されている 既定のインストールが終了した時点で、サーバ OS なのですから当 然のごとくサーバ用に動作が設定された状態になっています。この 状態では、Direct3D 拡張機能はおろか、クライアントの動作速度に 影響するほどの CPU リソースをバックグラウンド処理に割り当てて いるようです。
- 2) POP3 サービスが含まれるようになった

従来から SMTP サービスは含まれていましたが、Windows Server 2003 スタンダード版においても POP3 サービスが追加できるように なったようです.いままで Windows で標準のメールサーバといえば Exchange Server で、別途に購入を強いられるという印象が強かったのですが、SMTP/POP3 サービスが追加インストール可能(既定ではインストールされない)になったことで、標準のみでメールサービスから Web サービス、さらに接続規模を重視しなければ MSDE などのデータ接続なども利用できるようになりました.

接続規模やパフォーマンス性能を重視する場合は、メールサーバであれば Exchange、データベースであれば SQL Server などのマイクロソフト製品を選ぶか、他社製品を選ぶかを選択できるわけです。少なくともいままでのように、「メールサーバを立てたいけれど標準で POP3 がないから Linux ......」という簡単な話では済まなくなりそうです。

3) アプリケーション(クライアント)モードが速い

筆者の環境ではバックグラウンドモードからシステムの設定をアプリケーションモードに切り替えると、バックグラウンドモードの速度が嘘のように軽くなりました。さらに、評価版で使用していたときと比較しても、同一環境にもかかわらず速くなっていると感じられるほどの最適化がなされているようです。

この感覚を実際の数値として示してみたかったのですが、4月末現

在、公式な情報として公開されていないので、導入する機会がある場合には、ぜひとも同一の環境で以前のバージョンとの動作速度を比較してみてください。物理メモリが十分にある場合には、より速くなったと実感できる人は多いだろうと思います。

4) 既定の設定で非常にセキュリティ重視となっている

既定のインストールでは、サーバ用拡張サービスは「ファイル共有サービス」のみになっています。その他のサービスが必要な場合には、「サーバの役割管理」でサービスを追加していくように設定されています。もちろん不要なサービスはインストールせずに済むので、初期インストール後にサービスを停止して回るようなこともなくなりました。

クライアントレベルでも、Webのフロントエンドとなる Internet Explorer の初期設定では、クライアント用として設定されていないため、ActiveX コンポーネントはおろか、ほとんどのスクリプト処理が禁止もしくは使用不可となっており、ダウンロードさえもサイトを登録してから行うようになっています。こうした制限のため、Windows Update すらも、使用するためには設定を行わなければならないようです。

Windows Update に関しては、個々のサーバで行うよりも、Windows Update を中継する Software Update Service を使用したほうがよいのかもしれません.

#### • 今後の展望

Visual Studio .NET 2003 は、4月末現在、日本語版の製品出荷は未定ながら、すでにMSDN会員向けにダウンロード配布が開始されています。開発現場に対してはすでに製品の導入が始まっています。 筆者も開発環境の移行を済ませました。Visual Studio .NET 2003 については、稿を改めて紹介する機会もあるでしょう。

マイクロソフトの公式 Web ページでは、Office との連携に関わる部分の開発を統合するとのロードマップが公開されています。Office System 2003 は4月末現在で第2ベータの段階であり、今後の開発で変更される部分もあることでしょう。Windows Server 2003 との連携で発表されている Share Point Portal Service やグループウェアなどは、Office System 2003 で統合されて発売されるとのことなので、こちらも今後に期待したいと思います。

ひろはた・ゆきお OpenLab.

# ロゼッタストーンと WWW

#### 山本 強

いつの頃からかは知らないが、最近のブラウザは基本的に多言語対応となっており、見るだけならほとんどの外国語を扱うことができる。以前はWWWをさまよっていると文字化けしたWebページに遭遇してびっくりすることがよくあったが、最近では中国語やハングルであっても文字まで正しく表示されるのが普通になっている。それはそれで素晴らしい技術革新だと思うのだが、実際のところ日本語と英語ぐらいしか理解できない平均的な利用者には、そのありがたさが伝わってこない。

まぁ、そんなものかと思っていたある日、Yahoo!のトップページを眺めていて、その末尾に各国版 Yahoo!へのリンクがあることに気が付いた.試しに、中国語版 Yahoo!をクリックして驚いた。なんと日本語版 Yahoo!と同じようなデザインの中国語版 Yahoo!のトップページが表示されるのだ。誤解を避けるためにいうと、筆者は多言語対応に驚いたのではなく、日本語版と中国語版とのデザインの類似性に驚いたのである。筆者は、とっさにロゼッタストーンを連想してしまった。

#### 🧻 アイコンで理解する基本単語

中国語では、外来語も基本的に漢字で表記する。コンピュータなら 電脳、携帯電話なら手机あるいは手機と書く。こういった基本単語の 場合はだいたいわかるのだが、もう少し漠然とした概念語となるとわ からない。たとえば、モバイルである。この場合、モバイルというも のがあるわけではなくて、移動体通信を使った情報サービス全体を意 味している。これをほかの言語ではどう表記しているのだろうか。

現在の各国版の Yahoo!のトップページは、最上段に何個かアイコンが並んでいるデザインになっている。アイコンにはそれが何を意味するかの文字が付記されているから、同じデザインのアイコンに付記されている単語は基本的に同じであると考えられる。日本語版Yahoo!の携帯電話アイコンにはモバイルと注釈されているから、まず中国語系 Yahoo!を調べると同じアイコンが二つ見つかった。そして、そこには漢字で以下の添え字がしてあった。

短信(中国簡体字版, cn.yahoo.com)

簡訊(台湾版, tw.yahoo.com)

なんと、大陸と台湾では言い方が違っているらしい.短信は、「手短なメール」といった意味合いなのだろう.簡訊は、「簡単に情報入手」といった雰囲気が感じられる.勢いで欧米語圏を調べてみたところ、フランス、イギリスをはじめとして多くは Mobile であった.

変わったところでは、イタリア語は Cellulari、ドイツ語は Handy と表記してあり、多少の自己主張をしているようである。

このように、トップページから読み取れる中国語インターネット 用語にはなかなかの味わい深いものがある。チャット=聯天室、オークション=拍売、株式市場=股市などがアイコンから読み取れる。 株=股というのは日本語的にはびっくりもので、米国株式新聞は中 国語では美股新聞となり、なんとも怪しくなってしまう.

アイコンはリンク先の内容を抽象化したものだから、その先のページに出てくる用語の意味もだいたいわかってくる。先の「短信」の先を見ると、もっとユニークな業界用語が出てきた。携帯電話の着メロは「手機鈴声」と表記するらしい。まだまだあるのだが、この先は読者の練習問題として残しておこう。

#### 🧶 サーチエンジンも多言語対応

Yahoo!のようなリスト型の情報サービスで、単語のだいたいの意味合いが読み取れるのだが、自分が理解している意味が正しいかどうかを確かめる方法が必要である。そこで出てくるのが Google などの検索エンジンである。実際に試してみて驚いたのだが、Google は中国語と日本語の壁を越えて検索してくれる。検索エンジン内では中国語と日本語の文字の区別がなされていないらしい。Unicode はそういうコード体系だから、Unicode で内部データベースを作っていれば自然にそうなるのである。

Yahoo!のアイコンや分類でだいたいの意味がわかったら、今度はそれを Google で探索して用例を確認できてしまう。もちろん、確認するためには中国語の知識がある程度必要になるが、まれには英語や日本語の対訳が付いているのである。 Unicode による多言語文字の統一は、ローマ字文化圏による言語文化侵略のようにいわれることが多いのだが、このように言語をまたぐ検索ができるようになるというご利益もあるのである。

>

今回の話題は、Yahoo!も見方によってはロゼッタストーンに見えるというところから始まったのだが、なぜこんな使い方ができたのだろうか。何のことはない、アイコンという画像に必ず注釈がテキストでついていたということなのである。Yahoo!のデザインはテキスト中心になっている。すべての画像に解説文字をつけるというのは、Webページのユニバーサルデザインでは基本中の基本である。だから、多言語の関連付けができたともいえる。やっぱり基本は大事である。

やまもと・つよし 北海道大学大学院工学研究科電子情報工学専攻 計算機情報通信工学講座 超集積計算システム工学分野

# 特集 高速ロジックインターフェースから PCI Express, 10 Gigabit Ethernet まで

# 高速バスシステムの徹底研究

USBや Ethernet のようなインターフェースから PC/AT 互換機のメモリバスや CPU の FSB など、あらゆるバスインターフェースは高速化の一途をたどっている。これらは、デュアルエッジでデータを転送したり、低電圧化などの電気的な改良などの積み重ねにより実現されている。また、バスをシリアル化、または狭バス幅化を採用するシステムも増えてきている。

さまざまなバスインターフェースはどうやって高速化することができたのか、それを理解するにはまず、もっとも基本的なデバイス間通信の高速化技術を理解する必要がある。その技術の延長線上に、バスインターフェースの高速化が実現できていることがわかるであろう。

本特集では高速バスシステムというキーワードから、デバイス間通信、ボード間通信、筐体間通信、システム間通信など、用途や距離に応じたそれぞれの分野でよく使われている、またはこれから普及すると思われるバスインターフェースを取り上げて解説する。

| Prologue    | 高速バスいろいろ—— デバイス間データ転送か<br>ボード間/筐体間通信まで                         | `ら<br>桑野雅彦       |
|-------------|----------------------------------------------------------------|------------------|
| / LVDS      | ./SSTL/HSTLなどのシングルエンドから,<br>などのディファレンシャルまで<br>ロジック回路の電気的仕様いろいろ | 井倉将実             |
| 3.35Gl      | pps × 12 チャネルで最大 40Gbps の転送にも対応する<br>レル光モジュールによるデバイス間/         | 开启句 <b>天</b><br> |
| <b>∠</b> ボー | ド間通信の現状                                                        | 小林雄祐             |
| J PC//      | C/ATからHubInterface,HyperTransportまで<br>AT 互換機チップセットのデータ転送      | 桑野雅彦             |
| 4 PCI       | 高速拡張バスのスタンダード<br>Express 規格の概要<br>                             | 里見尚志             |
|             | ナライザを使って実際のバスの動作を見る<br>X の特徴とプロトコル                             | 村井康秀             |
| 6 PC周辺      | 2機器をより高速に接続するための<br>ハイスピード伝送の実現                                | 桑野雅彦<br>         |
| Appendix    | IEEE1394.b 最新動向                                                | 北山洋幸             |
|             | ドバンドの高速化でバックボーンもより高速に<br>igabit Ethernet の技術動向                 | 松本信幸             |













# Prologue

# 高速バスいろいろ —— デバイス間データ転送からボード間/筐体間通信まで

● PCの FSB. 最近やたらと速くなっていませんか?

高速化の変遷がもっともよくわかるものの一つに、PC/AT互 換機があります.CPUが年々速くなっている点が目に付きます が、ここでは外部バス、いわゆる FSB (Front Side Bus) に注目 してみましょう.

クラシック Pentium では 66 MHz だった FSB が、Pentium III では 133 MHz になり、最新の Pentium4 では 800 MHz というものまで登場しています.ただし Pentium4 の場合には、800 MHz といっても 1 クロックあたり 4 回のデータ転送が行われるので、実際のクロック信号の周波数は 200 MHz ですが,それでも高速化されていることには変わりありません.

しかしマザーボードに使われている基板は、FR4と呼ばれる昔から使われている一般的なもので、あれだけ多ピンのQFPやBGAを使っているのに、4層基板が普通なのです。CPUのクロック周波数ほどではないにしても、材質的に昔とそれほど変わらないプリント基板で、なぜこれほどの高速化が実現できたのでしょうか、その謎を解き明かすのが、今回の特集です。

● デバイス間データ転送の高速化今回の特集の第1章では、ロジック回路の高速化について解

説します。さきほど PC/AT 互換機の例を説明しましたが、たとえばメモリモジュールを考えてみましょう。昔の SIMM は 5V 電源の DRAM でした。それが 3.3V の SDRAM DIMM になり、DDR-SDRAM では電源電圧が 2.5V になり、さらに信号振幅も低電圧化されています。

そしてさらなる高速化手法として、Gbps オーダのデータ転送では、差動伝送方式が使われています。

メモリデバイスとチップセットなど、デバイス間データ転送の高速化のキーワードは次のようなものになるでしょう.

- 電源電圧の低電圧化
- 信号振幅の低電圧化
- 差動伝送化
- 半導体製造技術の進歩が高速化を支える

第1章で詳しく解説していますが、高速化のキーワードとしてあげた差動伝送などは、じつは昔から使われていた技術なのです。ただし、昔は通常ロジック回路と差動伝送回路は別々のブロックに分かれ、その間には変換回路を必要としました。

それが現在では、半導体製造技術の進歩により、一つのデバイスの中に実装することが可能になりました。これにより、高

#### 〔イラスト〕特集で解説する分野



## Column

特集で取り上げた以外の高速インターフェース

高速拡張バスやインターフェースには、今回特集で取り 上げたもの以外にもさまざまなものがあります.

ストレージ系としては、従来の IDE をシリアル化したシリアル ATA が普及し始めています。またサーバ用途では、ファイバチャネルと呼ばれるストレージインターフェースも使われています。

また FA 用途では、規格化された標準バスや標準インターフェースにしばられることなく、独自仕様のインターフェースで筐体間通信を行っているものなど多数存在します.

たとえば、図AのようにPCIやCompactPCI、VMEなどのシステム間を、光ファイバで接続するPCIやVMEボードが市販されています。内部的にLANなどのシリアル通信デバイス形態を採るものや、共有メモリ空間をもちデータ転送はすべてハードウェア的に行われ、ソフトウェアはメモリのリード/ライトを行えばすむものなど、さまざまなスタイルの通信インターフェースボードが市販されています。

また、FA 用途では多くの拡張スロットを必要とする場合もあります。そのような用途には PCI と互換性のある StarFabric なども普及し始めています。StarFabric のブリッジはソフトウェア的には PCI-PCI ブリッジに見えるので、図B のようにホストシステムと拡張スロットボックス間を StarFabric で接続した場合でも、従来のソフトウェアをそのまま使うことができます。これにより、従来の PCI-PCI ブリッジでは実現できないような数の PCI スロットを用意することもできます。また StarFabric は LAN のハブのようなスイッチデバイスもあるため、非常に柔軟な接続形態を採ることができます。

〔図 B〕 StarFabric による PCI バスの拡張



速データ転送に対応できるデバイスを安価に製造でき,1チップ化により基板面積も縮小できるなど,さまざまなメリットを 生み出しています.

USB2.0 や PCI Express などには差動伝送技術が使われていますが、これは通常ロジック回路と差動伝送回路を、1チップで安価に作れるようになった今だからこそ実現できるバスインターフェースではないでしょうか。

#### • バス/インターフェースの高速化

ここでデータバスの高速化を考えてみましょう。単純に考えれば、バス幅を広げ、転送クロック周波数を上げれば、それだけで高速化を実現できます。しかしこの方法では、基板配線遅延などの問題で、クロックに対してデータの到着がばらついてしまい、高速化が難しくなるのです。これをふまえ、現在ではバス幅を狭くしたりシリアル化を採用するバスシステムが増えてきています。

さらにクロックスキューの問題を解決するため、データとクロックを別々に送るのではなく、データにクロックを埋め込んで1本の線で伝送する方法も採用されています。

バス/インターフェースの高速化のキーワードは,次のようなものになるでしょう.

- ・狭バス幅化
- シリアル化
- クロック埋め込み
- 特集の案内

今回の特集で解説する内容はイラストのとおりです.

一見すると、ボード上のデバイス間通信と、筐体間をケーブルで接続するインターフェースは、まったく別物に見えます。 しかしそこで使われている高速化技術には共通するものがあり、いわゆる陸続きであることを忘れてはなりません.

くわの・まさひこ パステルマジック

# 高速ロジック回路の 電気的仕様いろいろ

井倉将実

高速バス/高速インターフェースを正しく理解するには、電気信号を高速に送るための基本 的な知識が必要になる。本章では、第2章以降で取り上げる各種バスやインターフェースを 理解する上で必要となる、高速ロジック回路の電気的特性などについて解説する。

(編集部)

#### 信号インターフェースのいろいろ

#### さまざまな信号インターフェース

現在、身の回りにある半導体デバイスのインターフェースに は、どのようなものがあるのでしょうか.

5V電源のTTLやCMOS, 3.3V電源のLVTTLやLVCMOS, さらには DDR-SDRAM など電源電圧の低いデバイスも多く使用されています。**表1**は,筆者が本誌 2003 年 1 月号で紹介した SH-4 搭載 CPU ボードの場合ですが,5Vの TTL や 3.3Vの LVTTL/LVCMOS, そして CPUや FPGA のコア電圧はさらに低いものになっています.

ほんの数年前は、TTLインターフェースとCMOSインターフェースの2種類さえ知っていれば、ほとんどのロジック回路の設計は事足りていましたが、それではせいぜい100MHz程度のバスクロックが限界でした。これを超えようとすると、TTLやCMOSインターフェースでは対応できず、別の信号インター

フェースが必要になります.

さらに、ここ1~2年ほどの間に、一気に Gbps 転送帯域までの要求が増えてきたように思います。このクラスになると、LVDS (Low Voltage Differential Signaling) に代表される差動インターフェースが必須です。筆者自身、いろいろなシステムの設計において、どのようなインターフェースを採用して信号伝送を行うか、いろいろ方式を検討する場面が増えてきました。

例として、標準的なマイコン(外部バスは LVTTL)に何らかの高速なメモリインターフェースを採用した製品の設計を想定してみましょう。一般的なマイコンは LVTTLをサポートしているので、そのままメモリとして SDRAM を接続することは可能です[図1(a)].

しかし、SDRAM よりもさらに高速なメモリである DDR-SDRAM を採用する場合には、DDR-SDRAM のインターフェースである SSTL2 (SSTL: Stab Series Terminated Logic) のサポートが必須です。これは LVTTL とは明らかに異なる信号であるため、LVTTLのシステムにそのまま接続することがで

〔表 1〕 筆者の設計した SH-4 システムの信号系

| デバイス       | 電圧    | 規 格                   |
|------------|-------|-----------------------|
| SH-4(コア)   | 1.95V | _                     |
| SH-4 (I/O) | 3.3V  | LVTTL3.3              |
| FPGA(コア)   | 2.5V  | _                     |
| FPGA (I/O) | 3.3V  | LVTTL3.3              |
| SDRAM      | 3.3V  | LVTTL3.3              |
| PCI        | 3.3V  | 3.3V PCI              |
| PIO        | 3.3V  | LVCMOS <sub>3.3</sub> |
| RTC        | 5.0V  | TTL                   |

〔図1〕異なるインターフェースをもつデバイスを接続するには



Interface July 2003

きません[図1(b)].

#### • 進化するインターフェース

本章で紹介する信号インターフェースは、技術の進歩とともに種類が増えてきたものです。たとえば、差動インターフェースの代表である ECL は、低電圧化の時代の波にのって PECLに代わり、さらに低電圧化して LVPECL に進化しました。おなじみの CMOS インターフェースも、現在では LVCMOS1.8 のように低電圧化されています。

今後,技術の進歩により,さらなる信号インターフェースが 提唱されることになるでしょう.そこで,次に現在の一般的な 信号インターフェースのおさらいをしておくことにしましょう.

#### • シングルエンド/ディファレンシャル

広く利用されている TTL インターフェースや CMOS インターフェースは、グラウンドを除けば1本の線で信号を伝送する1線式です。

しかし、Ethernet の信号伝達に使われる CML (Current Mode Logic) や、超高速なクロック供給回路などで広く使われている PECL/LVPECL、そして LVDS などは 2 線式です.

とはいえ、設計現場で「1線式インターフェース」や「2線式インターフェース | などと呼ぶことはありません.

TTLやCMOSのように、1本の信号線で伝送する方式を「シングルエンドインターフェース」、対してLVDSなどのように2本の信号線で伝送する方式を「ディファレンシャルインターフェース」と呼びます。

信号インターフェースは、大きくこの2種類の伝送線路方式に分類でき、取り扱い方法や使用帯域などが大きく異なります。また、シングルエンドとディファレンシャルでは、信号の伝わり方の考え方がまったく異なります。

#### • シングルエンドの信号の伝わり方

ロジック回路では、伝送線路が1本で伝わるシングルエンドの場合には、信号線以外に必ずグラウンドが必要です。そして、信号は「ある電圧から何ボルト以上あれば"H"レベル」、「何ボルト以下であれば"L"レベル」となります。

この「ある電圧」をスレッショルドレベルと呼び、TTLや CMOS の場合の電圧基準としてグラウンドレベルを使います。この場合のグラウンドレベルは、別に oV でなくてもかまいません。

信号を発生させるドライバ側と信号を受け取るレシーバ側の 共通電位の電位差が oV であれば、たとえほかの電源からみて 100V のオフセット(=上乗せ)があっても、それはグラウンド レベルになります。

このように、グラウンドレベルと信号線との電位差によって、信号が"H"レベルなのか"L"レベルなのかを伝える方式が、シングルエンドインターフェースの方式です。

ただし、高速なシングルエンドインターフェースになるとまた事情が変わります。 DDR-SDRAM や RAMBUS-DRAM のインターフェースである SSTL や HSTL (High Speed Transceiver

#### 〔図2〕外乱ノイズに強い



Logic) では、信号線とグラウンドレベルとの電位差だけでなく、 基準電圧  $(V_{ref})$  と比較して何ボルト以上の電位差があるかによって " $\mathbf{H}$ "レベルと" $\mathbf{L}$ "レベルを決めます。詳細は後述します。

#### • ディファレンシャルの信号の伝わり方

ディファレンシャルインターフェースは、一つの信号伝送の ために、必ず2本の信号線が存在します。

ディファレンシャルインターフェースの「ディファレンシャル」とは「差 (Differential)」を表していますが、何の差かというと、2本の信号線間に生じる電位差を示しています。そして、この2信号線間の電位差をみて、"H"レベルか"L"レベルかを判定します。

ディファレンシャルインターフェースは、必ず一つの信号につき2本の信号線が必要になるということで、配線数が増えてしまいます。たとえば、8ビットバス幅の信号伝送をするためには、シングルインターフェースの代表であるLVTTLインターフェースでは、GND信号と実際の信号線8本の合計9本で済みますが、ディファレンシャルインターフェースでは8ビット×2対で16本の信号線が必要です。また、グラウンド信号は必ずしも必須ではありませんが、通常は基板間/筐体間の基準電位を確保するために必要です。

#### • ディファレンシャルのメリット

シングルエンドインターフェースと比較すると、信号線本数が多くなるというデメリットのあるディファレンシャルインターフェースですが、そのデメリットに対してはるかに多くのメリットが存在します.

まず、各種ディファレンシャルインターフェースに共通する 大きな特徴の一つが、外乱ノイズに強いという利点です。

図2は、外部からあるパルスノイズが、より線(ツイストペア)のケーブルに乗ったことを想定しています。パルスノイズは、両方の信号線に同一時刻に同電位分が上乗せされますが、受信端はまったく影響ありません。

これは、両端子の電位差によりレベルを判定するというレシーバの基本的な動きを考えればよいのです。パルスノイズ電圧の電圧を $V_{noise}$ とすると、差動信号線の片側の信号線P端子上の電圧は、 $V_a+V_{noise}$ です。同様に、もう片側のN端子上の電圧は、 $-V_a+V_{noise}$ になります。ここで、差動レシーバの動き

を適用します。出力信号レベルは、Vp-Vなので、

 $(+V_P+V_{noise})-(-V_N+V_{noise})$ 

 $=+V_P-(-V_N)+V_{noise}-V_{noise}=V_P+V_N$  //QED という結果になり、 $V_{noise}$ の影響は消えます。これを「同相電圧除去」と呼びます。どの程度この同相電圧を取り除くことができるのかという性能を、アナログ OP アンプなどのスペックで

きるのかという性能を、アナログ OP アンプなどのスペックでは「同相電圧除去比」といい、〔CMRR: Common Mode(noise) Reduction Ratio〕と記されている場合もあり、dB(デシベル)で表記されています

上記の式は、CMRR が無限大の 100% 理想的な差動レシーバの動きを考えたものであるため、現実的にはここまで完璧に

 $V_{noise}$ の影響をキャンセルできません。しかし、簡単な差動レシーバでも、CMRR は  $20\mathrm{dB}=100$  程度の性能はあるので、 $V_{noise}$  の影響を 100 分の 1 にすることができます。

外乱ノイズは、何も外部からやってくるだけとは限りません.グラウンドプレーン上にディファレンシャルインターフェースを使ってデバイス間を接続したとき、このグラウンドレベルが他のデバイスの同時スイッチングの影響により数 100mV 程度のノイズが瞬間的に走ることもあります。このようなときに、同相電圧除去特性により、純粋な信号成分だけを取り出すことができるのも、ディファレンシャルインターフェースの大きな特徴でしょう.

## Column 1

FPGA が広める高速インターフェース?!

数年前まで、FPGA を採用して数百 Mbps のデータ転送を行いたい場合、かりに ECL/PECL インターフェースを採用しようとしても、普通に入手できる FPGA には直接接続できず、FPGA 以外に MECL100KH など (TTL でいう 74xx ファミリと同様なもの)の ECL-SSI/MSI デバイスをいくつも並べて論理回路を構成するしかありませんでした。または、 $TTL \leftrightarrow PECL$ 変換インターフェースデバイスがあったので、これを採用するという方法もありましたが、それでも基板面積の増大は避けられませんでした。

しかし、最近の高性能 FPGA は「ここまでヤルか!」というぐらいに多彩なインターフェースをサポートしています.これを実現するのに、このエリアは LVTTL、このエリアは LVDS というように、FPGA の I/O ピンに「バンク」という概念をもたせ、各バンクごとにインターフェースを切り替えて対応しているのです(図 A).

これにより、Gigabit Ethernet の物理層と DDR-SDRAM メモリ、そして PCI バスインターフェースを一つの FPGA に直結するというようなこともできます(図 B). 実際に、このような使い方は筆者の場合は日常茶飯事であり、当初はバンクという概念が面倒に思えていましたが、いろいろな信号インターフェースに対応

する手法としてはよく考えられているなと感心しています.

このように、少し前までの FPGA を使ったロジック設計では見向きもしなかった(?)信号名称が、最近の高性能 FPGA では自在に使えるようになり、それまでそれらのインターフェースを使ってこなかった設計者や新人設計者が慌てているという話も聞きます。今回解説している ECL や CML などは 20 年以上も前から使用されており、筆者にとっては新しいインターフェースでも何でもないと感じているのですが……

#### 〔図 B〕 さまざまなインターフェースを一つの FPGA に接続



#### 〔図 A〕最新 FPGA のバンク構成



#### シングルエンドインターフェース編

#### はじめに

10年ほど前までは5V駆動のICが一般的であり、ようやく3.3V系のドライバ群が出始めたところなので、デバイス間の接続で注意することは電位差だけでした。

しかし、ここ数年で低電圧駆動のデバイスの開発が進み、新 しい信号規格がいくつも出てきています。

ここでは、比較的よく使われているシングルエンドインターフェースについて解説します。

#### LVTTL

#### • LVTTLとは

LVTTLは、CMOS インターフェースと並んで、IC の接続インターフェースのもっとも基本である TTLの低電圧版です.

TTL インターフェースは、5V 系の IC 接続では非常にポピュラーな信号インターフェースです。しかしながら、近年になり、IC の駆動電圧が低電圧になってきたのにあわせて、信号インターフェースも低電圧化の要求がどんどん高まりました。そこで、旧来の5V 系 TTL インターフェースとある程度 互換が取れるような信号インターフェースの規格化が必要となり、TTL インターフェースの低電圧化がはかられました。それが、この LVTTL インターフェースです。

LVTTLというと、通常は 3.3V系の TTL インターフェースを指します。「通常」というのは、この 3.3V LVTTL が登場してからすでに 10年近くが経ち、3.3V LVTTL でさえも時代遅れになりつつあるからです。

現在では、2.5V系のTTLインターフェース、さらには1.8V系のTTLインターフェースが登場し始めました。

各社で呼称が違うということもありますが、複数の低電圧駆動系に対応したLVTTLインターフェースということで、LVTTLという名称の後に、駆動電圧を入れる場合があります。現在のところ、「LVTTL3.3」や「LVTTL2.5」、また「LVTTL1.8」

の3種類を目にします.

#### • LVTTL の特性

基本となる TTL インターフェースの入出力部分の回路を 図3に、また TTL の特性表を表2に示します。この表は、ある FPGA の I/O ピンを、LVTTL インターフェースにした場合 のいくつかの重要な特性パラメータを表しています。

- VoH: "H"レベル出力時の最低出力電圧
- Vot : "L"レベル出力時の最大出力電圧
- V<sub>m</sub>: "H"レベルとして判定する場合の入力最低電圧
- $\bullet$   $V_{I\!\!L}$  : "L"レベルとして判定する場合の入力最大電圧

新人技術者の養成研修などの際に、特性パラメータ表に最大 値や最小値が明記されていないことについて疑問をもたれ、質 問を受けることがあります.

たとえば、3.3V LVTTLの $V_{OH}$ パラメータの場合、最低出力電圧である 2.0V はわかるが、最大時 (MAX) が明記されていないという点です。この 3.3V LVTTLの場合には、 $V_{OH}$  (min) で

#### 〔図3〕TTLインターフェースの入出力部分の回路



[表 2] TTL インターフェースの特性(LVTTL の特性はアルテラ社 Stratix のデバイスデータシートより)

| パラメータ                                 | 74LS00 |      | LVTTL3.3 |        |      | LVTTL2.5 |        |      | 単位      |      |
|---------------------------------------|--------|------|----------|--------|------|----------|--------|------|---------|------|
| 7.77                                  | 最小     | 標準   | 最大       | 最小     | 標準   | 最大       | 最小     | 標準   | 最大      | 十 1亿 |
| Vcc:動作電圧                              | 4.75   | 5.00 | 5.25     | 3.00   | 3.00 | 3.60     | 2.38   | 2.50 | 2.63    | V    |
| $V_{^{\! \! \! H}}: H$ レベル入力電圧        | 2.00   |      |          | 1.70   |      | 4.10     | 1.70   |      | 4.10    | V    |
| $V_{\prime\prime}$ : L レベル入力電圧        |        |      | 0.80     | - 0.50 |      | 0.70     | - 0.50 |      | 0.70    | V    |
| <i>II<sub>H</sub></i> : H レベル入力時リーク電流 |        |      | 0.02     | - 0.01 |      | 0.01     | - 0.01 |      | 0.01    | mA   |
| V <sub>OH</sub> : H レベル出力電圧           | 2.70   | 3.40 |          | 2.00   |      |          | 1.70   |      | 2.10    | V    |
| Vol.: Lレベル出力電圧                        |        | 0.25 | 0.40     |        |      | 0.45     | 0.20   |      | 0.40    | V    |
| <i>I<sub>OH</sub></i> : H レベル出力時電流    |        |      | - 0.40   |        |      | - 25.00  |        |      | - 25.00 | mA   |
| <i>IoL</i> : L レベル出力時電流               |        |      | 8.00     |        |      | 25.00    |        |      | 25.00   | mA   |

規定された以上の電圧を出していれば、それで動作が保証されるからであり、厳密に最大値を知ろうとした場合には、信号インターフェースを出力するIC内部の出力I/Oパッドの構造が公開されていないかぎりわかりません。

ですが、どんなに最大の電圧を出そうとしても、I/O ピンに 印加された駆動電圧までしか電圧を持ち上げることはできない ので、そういう観点でいえば「最大値は 3.3V です」といっても 間違いではありません、

しかし、すべての IC が最大 3.3V を出力できるかといえば、これも正しくありません。

先の**図3**で示したように、出力段がトーテムポール構造になっている場合には、トランジスタの $V_{CE}$ 電圧分があり、そして普通は電流制限抵抗(図では  $120\Omega$ 抵抗)があるので、過電流が流れた場合にはこの抵抗×電流値分+トランジスタの $V_{CE}$ 分の電圧ドロップが必ずあります。結果的に、出力パッドに現れる電圧は 3.3V よりも低くなります。

#### ● TTL デバイスと LVTTL デバイスの接続

また、旧来から使われ続けている 5V 系 TTL デバイスと 3.3V 系 TTL デバイスは、 $V_H$  に要求される電圧がほとんど同じなのですが、それではマージンが小さいために、双方を接続した場合には信号伝送を 100%保証することができない場面も少なくありません。

ここで再度,**表 2** の SN74LS00 についての電気的特性を見てください。SN74LS00 は,5.0V 電源で駆動します. $V_{OH}/V_{OL}/V_{IH}/V_{IL}$  の各 4 パラメータは,いずれも LVTTL 3.3V 系に合致します.ですが,余裕度 (マージン) を考えると,あと一息ほしいところです.

たとえば、5.0V系 TTL が $V_{HH}$ =2.0V (MIN) に対して、3.3V系 LVTTL が $V_{OH}$ =2.4V (MIN) ぐらいあれば、400mV 程度の余裕 度、つまり 20%のマージンがあるので、よほどのことがない限りおかしくなることはないでしょう。

そこで、必要に迫られて昔の回路をそのまま使わなければならないような場合は、次に紹介する 3.3V の LVCMOS や 2.5V の LVCMOS を使うことをお勧めします。

〔表3〕CMOSインターフェースの特性

| パラメータ                                    | 74VH                         | C245 (Ta | = 25)    | 単位      |
|------------------------------------------|------------------------------|----------|----------|---------|
|                                          | 最 小                          | 標準       | 最大       | 177     |
| Vcc:動作電圧                                 | 2.00                         |          | 5.50     | V       |
| $V_{\prime\prime\prime}$ : H レベル人力電圧     | 1.50                         |          |          | V       |
| $V_{\scriptscriptstyle I\!L}$ : Lレベル人力電圧 |                              |          | 0.50     | V       |
| II <sub>H</sub> : H レベル人力時リーク電流          |                              |          | 0.10     | $\mu$ A |
| <b>V</b> <sub>OH</sub> : H レベル出力電圧       | <i>V</i> <sub>CC</sub> × 90% |          | $V_{cc}$ | V       |
| $V_{OL}$ : Lレベル出力電圧                      | 0.00                         |          | 0.10     | V       |
| IOH : Hレベル出力時電流                          |                              |          | - 25.00  | mA      |
| Iot: Lレベル出力時電流                           |                              |          | 25.00    | mA      |

#### **LVCMOS**

#### • CMOSとは

CMOSの最大の特徴は、出力信号電圧がI/Oパッド駆動用の電源電圧の全範囲に振幅する点です。また、入力の電位も、電源電圧のちょうど中心電圧で切り替わります。

入力ピンの内部構造は、一般的に P チャネル MOS-FET と N チャネル MOS-FET の組み合わせである CMOS 構造です.出力ピンも同様に MOS-FET 構成である場合が一般的です.

電気が流れることによる電界効果によって素子の ON/OFF を行う FET は、電流が流れることによって素子の ON/OFF を行うトランジスタと比べて、理論上は電流が流れないという利点があります。

電流が流れないということは非常に抵抗値が高いということであり、そのため消費電力はほぼゼロです。通な言い方(?)をすれば「入力インピーダンスが非常に高い」となります。

それゆえ、LVTTL信号インターフェースに比べて、入力ピンに何も接続されていない状態(フローティング)では、外部からのノイズなどで容易に誤動作を起こすという症状も現れます。

同様に、高入力インピーダンスということは、入力側に接続されるデバイスが小電流しか発生できない場合にも、ロジックとして接続できるという利点もあります。よって、フォトセンサや微小な磁力を感知するホール素子などのセンサアンプ部に利用されることもあります。

さらに、CMOS は高耐圧であり、たとえばオンセミコンダクタ社が製造/出荷している MC14xxxファミリは、動作電圧が  $3\sim18V$ です。この広い動作範囲は、高耐圧のメタルゲートで構成された CMOS FET であるからこそ実現できるものであり、TTL デバイスではとても真似できません。

#### • LVCMOSとは

LVCMOS は LVTTL と同様に、低電圧駆動 CMOS です. 動作、先ほど紹介した CMOS 最大の特徴と同じく、信号電圧が電源電圧まで振幅するというもので、駆動電圧の違いがあるだけです.

LVTTLの場合と同じように、駆動電圧によって「LVCMOS3.3」や「LVCMOS2.5」、「LVCMOS1.8」と明記されているデータシートもあります.

表 3 に、低電圧版ハイスピード CMOS デバイスである MC74VHC245 デバイスの LVCMOS 特性パラメータを示します。 LVTTL 3.3 の場合は $V_{OH}$  の電圧が、最小 2.4V、最大値は規定なし(= $V_{CCIO}$ 電圧と考える)でしたが、LVCMOS 3.3 やLVCMOS 2.5 の場合では、 $V_{OH}$  電圧はほぼ $V_{CCIO}$  と同じであることがわかります。同様に、 $V_{OL}$  の電位もほぼグラウンドレベルと、I/O パッドに対する印加電源電圧をフルに振幅していることがわかります。

入力電圧側は駆動電圧  $V_{DD}$  に依存しますが、 $V_{II}$ 、 $V_{IH}$  ともに、 $V_{DD}$  電圧の 70%以上/30%以下さえ保証できれば、直接受け付け

ることができます。

#### • CMOS の入出力回路

これらの特性は、CMOS デバイスの入出力 I/O パッド部分の回路構成によるものです。

この**図 4** は、もっとも基本的な 2 入力 NAND ゲートの回路 ですが、出力段が P チャネル MOS-FET E N チャネル MOS-FET のトーテムポール構成になっています。

PNPトランジスタと NPNトランジスタで構成された LVTTL の出力段回路(図3)と似ていますが、トランジスタとは違って MOS-FET なので、ON にすればドレインもソースも同一電位 になります。これにより、上側の出力 MOS-FET が ON になれば(この場合は下側の出力 MOS-FET は OFF)、出力ピンには  $V_{DD}$ 電圧にかぎりなく近い値になります。

逆に、下側の MOS-FET が ON になれば、上側の MOS-FET は OFF になってグラウンドと接続されるので、出力ピンの電位は限りなくグラウンドレベルに近い値になります.

入力ピン近辺の四つの FET 以降にある P-MOS/N-MOS のトーテムポールゲートは、インバータゲートです。

この段数が奇数段であれば、初段の入力段がインバータ出力なので、結果として正論理出力=ANDゲートになり、偶数段であれば負論理出力=NANDゲートというわけです。

また、**図5**は2入力NORゲートの回路図です.**図4**と見比べてどうでしょうか.回路を構成する部品点数は変わらずに、初段の入力ピン周辺に配置されたMOS-FETの並び方が変わっただけだと思いませんか.

じつは、MOS-FET で構成された NAND ゲートと NOR ゲートの違いというのは、そのものずばり、入力段における MOS-FET の並び方の違いだけなのです。

初段の $Q1 \sim Q4$ で示される四つの FET のみで、NAND ゲートなのか NOR ゲートなのかが決まり、後段の Q5-FET 以降は出力時のインバータ回路によるバッファ回路です。こちらも NAND ゲートと同じように、奇数段と偶数段で NOR ゲートと OR ゲートが切り替えができます。

#### • CMOS デバイスと LVCMOS デバイスの接続

TTLとLVTTLの接続では、マージンを考えると若干不安が 残るという話をしました。

これは、5.0V 系 TTLの $V_{IH}$  = 最小2.0V に対して、3.3V 系 LVTTLの $V_{OH}$  も同一の2.0V であるため、たとえばインピーダンスのマッチングや反射を防ぐためにデバイスの間にダンピング抵抗などを入れた場合には、どうしても若干の電圧ドロップが生じてしまい、マージンが取れないことを想定しています。

このような場合でも、LVCMOSであれば、"H"レベル出力電圧 $V_{OH}$ はほぼ $V_{DD}$ 電圧まで振幅するので、"H"レベル側は充分にマージンが取れます。"L"レベル出力電圧 $V_{OL}$ も、グラウンドレベル付近まで落ちるので、こちらも問題なくインターフェースが取れます。

さらに、2.5V駆動でも問題なくインターフェースできる点に

#### (図4) 2入力 NAND の回路



#### 〔図5〕2入力 NOR の回路



注目してください。

図 6 は、各 TTL/LVTTL インターフェースと CMOS インターフェースの入出力電圧をグラフに表したものです。なお、この図の CMOS デバイスは、表 3 で紹介した MC74VHC245 のものです。このデバイスは通常は  $V_{DD}$ =5.0V で動作させますが、DC 特性としては 2.0  $\sim$  5.0V の間であり、スペックシート上でも 3.3V 駆動の場合の電気的特性も明記されています。

つまり、現在の主流である低電圧駆動インターフェースを使ううえで、これらの LVCMOS タイプデバイスを用いて、LVCMOS 2.5 や LVCMOS3.3 インターフェースを採用しておけば、同一インターフェース はもちろんのこと、さらに 5V-TTL や LVTTL3.3、そして LVTTL2.5 インターフェースのすべてに対

## 特集 高速バスシステムの徹底研究

#### [図6] LVTTL と LVCMOS の電圧比較



応することができます.

以上、LVCMOS さえあれば何とかなるという主旨で解説しましたが、じつのところ LVCMOS では昨今のプロセッサやメモリ周辺回路に見られる、100MHz を超えるようなクロックでは、信号伝達が厳しくなりつつあります。詳細については、コラム2を参照してください。

これに対処すべく考えられたのが、次に説明する SSTLや HSTLです.

#### SSTL

• 高性能 FPGA でより身近になったインターフェース シングルエンドインターフェースの中でも、いまもっともホットな信号インターフェースが、この SSTL インターフェース ではないでしょうか、 SSTL インターフェースは、後述する HSTL インターフェースとともに、高速なメモリインターフェース用に広く利用されています。

SSTLインターフェースは、パソコンやグラフィクスカード

〔図7〕スタブ



の主記憶メモリで・般的な DDR メモリで使われています。さらに、この SSTL インターフェースは DDR メモリだけでなく、大規模/高速 FPGA 間の接続インターフェースに採用する例も少なくありません。

FPGAでは、ASICやゲートアレイよりも豊富な I/O インターフェースオプションを用意したものが多く発売されてきました。LVTTLや LVCMOS はあたりまえですが、SSTLや後述する HSTL はほぼ標準的な I/O オプションと化しており、高性能 FPGA を使った場合には容易に SSTL インターフェースを選択できます。

#### • SSTLとは

SSTLとは、前述のとおり Stub-Series-Terminated-Logic の 頭文字をとったものです。日本語にすると「分岐に対して直列 のターミネーションを挿入した伝送線路インターフェース」と でもなるでしょうか? 日本語に訳すと、何やら呪文のごとく 怪しげな言葉の羅列になってしまいますが、要はスタブに直列 抵抗を挿入した伝送線路ということです。スタブは、伝送系路上から分岐した信号線の部分を示します(図7).

この信号インターフェースは、EIAJ/JEDEC 規格に正式に登録されているものであり、I/O 電源電圧により、3.3Vであれば SSTL-3、2.5Vであれば SSTL-2、そして 1.8V であれば SSTL-18(現在規格策定中) という使い分けがなされます。そして信号 経路の形状と直列に挿入されるターミネーション抵抗の位置や値により二つのクラスがあり、SSTL-2 クラス 1 などの呼び方がなされます(**図8**)。

#### • **V**<sub>ref</sub>と比較することでレベル判定

SSTL (や後述する HSTL) インターフェースが、LVTTLや LVCMOS と大きく異なる点は、既存の LVTTL や LVCMOS が グラウンドからの信号線の電位によって信号レベルを決めていたことに対して、これらのインターフェースでは、 $V_{ref}$ (リファレンス:基準) 電圧と信号線上の電位を比較することによって

#### 〔図 8〕SSTL のクラス



信号レベルを決めているということです。

SSTL の場合には、I/O 電源電圧の 50% (または 45%) の電圧 を  $V_{ref}$  として、この電圧よりも高いか低いかで、" H "レベルか " L "レベルかを判定します。そして、このときの" H "/" L "レベルおのおのの電位差は 800mV 程度と、いままで紹介したインターフェースよりも低くなっています。

また、SSTL/HSTLでは、さらにこの $V_{ref}$ と信号線を抵抗で終端(ターミネーション)します。

もちろん、LVTTLやLVCMOSのときのように、グラウンド電位 (通常は oV) と比較することは何ら悪いわけではありませんが、ターミネーションが必須である伝送線路を想定した場合、正の"H"レベルと正の"L"レベルでターミネーションするよりも、電圧が+/-逆ではあるが、同一の電位がとれる「中間電位」でターミネーションするほうが、その経路に流れる電流も一定になります。

たとえば、"H"レベル 2.0V、"L"レベル 0.8V の LVTTL を  $50\Omega$  でターミネーションしたとき、"H"レベル時には 40mA、"L"レベル時には 16mA の電流が流れます。しかし、中心電圧 の 1.4V を中心にしてターミネーションすれば、"H"/"L"レベルともに 12mA の電流ですみます。振幅も 1200mVp-p となり、立ち上がり/立ち下がり時間の短縮にも貢献できます。

SSTL2 を例にすると、中心電圧= $V_n$ (ターミネーション電圧)は 1.25V(I/O電圧の 50%)、SSTL インターフェースの受信側は $V_{ref}$ 電圧とターミネーションされた信号電圧を比較して"H"が"L"かを判定しています。このことから、LVTTL/LVCMOSなどと同一スルーレートであれば、 $t_R/t_F$ はこちらのほうが小さくなるということで、さらなる高速化に対応できることになります

#### • DDR-SDRAM にみる SSTL の動作

ところで、昨今流行の DDR-SDRAM メモリは 2.5V 系電源電圧で駆動します。そのため DDR-SDRAM とのインターフェースに使われている SSTL インターフェースは、I/O 電源電圧 2.5V の SSTL 2 クラス 1 、またはクラス 2 ですが、本章では SSTL 2 クラス 2 を参考に解説します。

図9は、DDR-SDRAMを採用したシステム設計例としてのパソコンをイメージした図です。 SSTLはスタブ(分岐点を複数もつ配電線路用)に取り扱うことができる信号インターフェースです。パソコンのメモリまわりを考えてほしいのですが、ユーザーは1枚単位でDDRメモリを購入して挿入することができます。

これはまさに、スタブがどんどん増えていくことそのものです(**図10**)が、このような設計を想定した場合に、正しく信号伝送ができるように考えられているのが SSTL です.

図 11 は、SSTL の動作を示したものです。ス

#### [図9] DDR-SDRAM 搭載マザーボード



タブが二つあることを想定してみましょう。ドライバからレシーバへの配電線路では、 $50\Omega$ の基板固有の特性インピーダンスがあり、さらにスタブ点(A)の先には、おのおの $50\Omega$ の抵抗が接続された T分岐の回路が存在します。この抵抗は、特性インピーダンスとのマッチングを取るためのターミネーション抵抗です(図 10 中の $R_t$ 抵抗)。すでに述べたとおり、SSTLの場合には、この抵抗の先は $V_{rrf}$ と同一の電位になります。

伝送線路の特性インピーダンスとマッチングを取るための $R_t$  は終端抵抗ですが、 $R_t(\mathbf{a})$  と $R_t(\mathbf{b})$  はともに $V_t$  に終端されているので、この図をさらに変形していくと、スタブからみてその先の終端抵抗は $1/2 \times R$  になります。

#### 〔図 10〕 DDR 信号経路

 $V_{POS} = 3.3V (SSTL-3)$   $V_{POS} = 2.5V (SSTL-2)$ PMOS D

NMOS S  $V_{NEG}$   $V_{NEG$ 

# 特集 高速バスシステムの徹底研究



# Column 2

スルーレートについて

#### ● LVTTL/LVCMOS の限界

ここで、かりに 1V の電位を 1ns で出力できるドライバがあるとしましょう。アナログ OP アンプ回路の代表的なパラメータであるスルーレートで、このドライバの性能を  $\mu s$  単位の遷移値に換算すると  $1000V/\mu s$  という数字になります。この値は、「高速 OP アンプ」と呼ばれる部類のもつ性能であり、相当優秀な出力アンプです(図 C).

ここで 2.5V 駆動の LVCMOS を考えた場合、 2.5V の 10%が" L" レベル、 2.5V の 90%が" H"レベルというのが一般的なレベルの判定値になります。 つまり、 2.5V の 80%の範囲 = 2.00Vp-p が、LVCMOS ドライバが出力を変化させる最低の範囲の電位です。

このため、 $2.00V \div 1V/ns = 2.00ns$  という値が導き出され、容量性負荷や抵抗などの障害がいっさいない状況でも、レベルの遷移に2.00ns 秒の時間が必要であるということになります.

これに IC などが接続されれば、ピンの入力容量(ファンアウト) 負荷  $C_{I}$ (ロードキャパシタと呼ぶ)が追加され、さらに抵抗が間に 入れば、配線やピンの $C_L$ 値によりフィルタが形成され、さらに遅くなります。

負荷のない理想状態のみを考えても、1クロックを送るのに" L" レベルから" H"レベル、そして" H"レベルから" L"レベルへの変化で 4ns を超えます. 結果として、これだけでも 250MHz より高速なスイッチングはできないわけす(図 D).

現実的な話として、3.3V 系 LVTTLや LVCMOS では、信号の伝送速度はおおむね 133MHz ぐらいが限界ではないかと筆者は考えています.

#### • もっと狭い電圧範囲なら……

スルーレートが同じ能力だとしても、変化させる電圧の範囲をもっと狭くできれば、もっと高速にスイッチングさせることが可能になるはずです。これが、SSTLやHSTLのアイデアです。

たとえば、SSTL インターフェース(一般的な DDR-SDRAM では 2.5V の SSTL2 クラス 1/2 を採用) では、電源電圧やグラウンドとは 別に基準電圧を用意し、この基準電圧と信号線の電位でレベル判定 をします。この SSTL2 インターフェースを例にして考えてみましょう (図  $\mathbf{E}$ ).

ドライバの能力は、先のものと同じ 1V/ns のドライバとします.

#### (図C) LVTTLのスルーレート



#### 〔図 D〕伝送できる最大クロック周波数



すると、ドライバ直前の $Z_o$ (特性インピーダンス)とR,は一致しなくなり、ここで1/2の信号反射が発生します。これを防ぐためには、半分になってしまった終端抵抗の合成抵抗値を持ち上げて特性インピーダンスと一致させる方法がSSTLではとられています。

そこで、スタブの直前に  $1/2 \times R$ 、に相当するスタブ抵抗を直列に挿入することで、特性インピーダンスとスタブ抵抗 + 終端抵抗の合成抵抗値を一致させることができ、これにより反射を防ぐことができるようになります。この伝送線路に直列で挿入されるスタブ抵抗を、R、(Stub-Resister) と呼びます。

再度 DDR-SDRAM を含めた回路系を見てみましょう。各ドライバの直前には、すべてスタブ抵抗  $R_s$  が入っていることがわかります。そして、どのドライバからみても、 $V_u$  に接続されている  $R_t$  は 2個しか見えておらず、先に解説した模式図にあるように、 $R_t$  は結局  $1/2 \times R_t$  となることがわかると思います。特性

インピーダンスは $R_i$ と同じ値なので、そこでドライバそれぞれに $R_i$ を入れることで、マッチングを取っているのです。

なお、レシーバ側の入力インピーダンスは非常に高く、実質電流は流れないことで、いくつR、が挿入されていようが伝送線路には影響がないということがあらかじめ前提としてあります。

SSTL インターフェースの特徴は、 $V_{ref}$  と信号レベルを比較するので、低い振幅で伝送を行う点であることは先に述べました

表4に、SSTLの各スペックに基づいたDCレベルの電気的特性を示します。およそ基準電圧に対して、400mV以上の電圧振幅さえあれば、レベル判定が正しく行われるという点は、LVTTL/LVCMOSのそれとは違って、非常に驚くところです。

"H"/"L"レベル合わせて800mVp-pあれば信号伝送できるので、同一スルーレートであればLVTTL/LVCMOSのおよそ2

SSTL2 は 2.5V の 1/2 電位である 1.25V が基準電圧となります. DDR-SDRAM を考えた場合、そのほとんどが基準電圧に対して  $\pm$  300mV を超えるとレベル変化と認定されます。すなわち、"L"レベルは 950mV、"H"レベルは 1550mV の電圧となります。

その電位差は600mVとなるので、遷移時間は $600mV \div 1V/ns$ で、600psであることがわかります。

LVCMOS と同様に、立ち上がり時間と立ち下がり時間を加算しても 1.2ns なので、およそ 800MHz ぐらいの転送帯域まではいけそうな気配です。

つまり、スルーレートが同一の特性をもつドライバであっても、 遷移時間を小さくすることで高速なデータ信号を行えるわけです。

現実的な話では、現在 DDR-SDRAM でバスクロックが 200MHz というものがパソコンの世界には広まってきており、一部では DDR-2の 533 (266MHz) や 600 (300MHz) というものもあります.

ドライバの性能と小振幅電圧インターフェースの進化により、シ

ングルエンドでも 500MHz ぐらいまではまだまだ軽く進化しそうな雰囲気です.

#### ノイズ耐性

しかし、今度は振幅が小さいために、たとえば平走する隣り合った信号ラインからノイズが飛んで、信号の電位がずれてしまった場合に対する余裕度、つまりノイズマージンは小さくなります。ノイズマージンが小さいと、とくにグラウンドレベルが多少不安定であった場合には誤った信号とみなされてしまうかもしれません。

写真 A は、128 ビットデータバスをドライブした際にグラウンドレベルがずれてしまう現象を観測した波形です。これが高速でシステムを動作させると無視できなくなる「グラウンドバウンス」です。

とはいえ、この $V_{ref}$ がグラウンドバウンス発生時と同様にふらついていたのでは意味がありません。SSTLやHSTLでは、この $V_{ref}$ の安定度も重要な設計留意点となります。





〔写真 A〕グラウンドバウンスのようす¹)



#### 「表4」SSTLの特性表

| SSTL                           | SST                  | ГL3                    | SST                  | ΓL2        | 単位 |  |
|--------------------------------|----------------------|------------------------|----------------------|------------|----|--|
| 331L                           | クラス1                 | クラス2                   | クラス1                 | 1-17       |    |  |
| $V_{DDQ}$ : 駆動電圧               | 3.5                  | 3V                     | 2,                   | 5V         | V  |  |
| V <sub>u</sub> :ターミネーション<br>抵抗 | $V_{DDQ} \times 0.2$ | µ <sub>5</sub> (= 1.5) | $V_{DDQ} \times 0.5$ | 5 (= 1.25) | V  |  |
| $V_{ref}$ :リファレンス電圧            | $V_{DDQ} \times 0.2$ | $_{15}(=1.5)$          | $V_{DDQ} \times 0.5$ | V          |    |  |
| Hレベル電位(DC 最小)                  | $V_{\it ref}$ -      | + 0.2                  | $V_{ref}$ $\dashv$   | V          |    |  |
| Lレベル電位(DC 最大)                  | $V_{\it ref}$ -      | - 0.2                  | $V_{ref}$ -          | V          |    |  |
| R <sub>t</sub> :ターミネーション<br>抵抗 | 50                   | 25                     | 50                   | 25         | Ω  |  |
| $R_s$ :シリーズ抵抗                  | 25                   | 25                     | 25                   | 25         | Ω  |  |
| I <sub>OH</sub> (計算值)          | 8                    | 16                     | 7.6                  | 15.2       | mA |  |
| $I_{ol}$ (計算値)                 | <b>- 8</b>           | - 16                   | - <sub>7.6</sub>     | - 15.2     | mA |  |

倍の信号伝送帯域が期待できます.

たとえば通常、シングルエンドインターフェースにおいて、 t<sub>B</sub>/t<sub>E</sub>の時間はサイクルタイム全体の5%以下に抑えることがほ とんどです. このため、かりに 4V/ns のスルーレートであれば、 LVCMOS2.5 の場合には各 0.625ns の  $t_p/t_p$  なので、1 サイクル は 25ns (つまり 50MHz 程度)となります。それに対して、 800mVp-p 振幅の SSTL2 では各 0.2ns の  $t_R/t_F$  であるため、1 サ イクルは8ns(つまり125MHz)となります。

なお、執筆時点では、SSTL 1.8 については EIA/JEDEC 規格 でまだ規定されたものはありませんが、SSTL2の回路電圧の VDDQ を 1.8V にする以外は、 $V_{tt}$ や  $V_{ref}$ の概念や電圧振幅は同 様なものです.

また、信号振幅が小さいことで外部に影響を与えるノイズ発 生量、いわゆる EMI が小さくなり、隣りあう信号線間との結 合容量によって発生するクロストークの影響も小さくなります.

#### SSTLの応用

SSTL信号の応用としては、単に LVTTL/LVCMOS の置き 換えというだけでなく、DDR-SDRAM に代表されるようにダ ブルデータレート、つまり一つの信号線で、クロックの立ち上 がりと立ち下がりエッジを利用して2倍のデータ転送を行う方 法があります.

また、昨今の FPGA では I/O インターフェースオプションが 豊富であり、I/O 電圧が 2.5V の場合には LVTTL, LVCMOS と同時に SSTL2 を同一の I/O パッドや I/O バンクで使うよう なことも可能です(ただし、SSTLを利用する場合には別途 $V_{ref}$ 基準電圧を供給する必要がある).

これによって、大容量の転送を複数の FPGA 間で行わなけれ ばならないような場合には、SSTLインターフェースは、 $V_{ref}$ 基 準電圧電源とターミネーション抵抗の追加によって利用できる という利便性があります.

なお、ダブルデータレート転送を行う DDR-SDRAM メモリ の動作についての詳細は、姉妹誌『デザイン ウェーブ マガジ ン』2003年3月号を参考にしてください。

#### **HSTL**

#### • HSTLとは

HSTLインターフェースは、1.5V電源電圧で駆動する高速シ ングルエンド信号インターフェースで、 ラムバス社のラムバス メモリを駆動するインターフェースとしても知られています. また、PowerPCのL3キャッシュに接続される超高速のキャッ シュメモリ用 SRAM にも使われています.

電源電圧が1.5V. そして信号レベルはSSTLインターフェー スよりもさらに低い電圧レベルであるため、LVTTL/LVCMOS や SSTL に比べて次の点で効果が期待できます.

- リファレンス電圧と比較した電圧振幅により信号レベルを確 定するので、SSTLと同様にドライバの供給電圧には依存し ない. つまり, 多少の電源変動には強い
- V<sub>ref</sub>とドライバの電圧はユーザー側である程度融通が利く
- ●信号振幅が SSTL よりもさらに低いので、外乱ノイズの発生 が少なく消費電力も小さい

HSTLでも、SSTLと同様に、信号経路の構成により複数の クラスがあります.

#### ▶ HSTL クラス 1

 $V_{DDO}$ (ドライバ/レシーバ駆動電源電圧)に 1.5V, そして  $V_{ref}$ には $V_{DDO}$ の1/2である0.75Vをレシーバのリファレンスピンに 供給する方式です.

伝送線路は、通常 $50\Omega$ の終端抵抗で $V_{ref}$ に終端されます。こ れは、他のクラスでも同じです、信号の振幅はリファレンス電 圧を中心として  $\pm$  400mV なので、 $R_c=50\Omega$  の場合には" L"レベ ル/" H"レベルともに8mAの電流が流れます。これにより、 1ピンあたり 3.2mW の電力が抵抗で消費されます.

信号経路は、SSTLクラス1とまったく同一です。

#### ▶ HSTL クラス 2

HSTLクラス1の例と同様に、こちらもSSTLクラス2と同 一の信号経路です。ドライバのピン近辺とレシーバのピン近辺 にターミネーション抵抗を介してリファレンス電圧に接続され ます. ターミネーション抵抗は、50Ωが一般的です.

#### ▶ HSTL クラス 3

HSTL クラス3では、ターミネーション電圧とリファレンス 電圧がクラス1,クラス2と異なります.

信号経路はHSTLクラス1と同一ですが、 $V_{tt}$ はドライバ/レ シーバの駆動電源電圧である $V_{ppo} = 1.5 \text{V}$ と同一になります. ターミネーション抵抗は通常  $50\Omega$  であり、 $V_{ppo}$  に接続されま す. そして、 $V_{ref}$ は $V_{DDO}$ の60%にあたる、0.9Vになります.

 $V_{tt}$ がドライバ/レシーバの駆動電圧であるということは、"H" レベルの信号はほぼ $V_{DDO}$ そのものになることが想像できます. それに対して、"L"レベルは最大で0.4Vと規定されています. 実際には,V<sub>ppo</sub> – V<sub>#</sub>の o.6V が振幅電圧として,同様に" L "レ ベルも $V_{tt}$  - 0.6V となるので、0.3V ぐらいまで下がります。

#### 〔表5〕 HSTL の特性表

| HSTL                        | クラス1                | クラス2                | クラス3                         | クラス4                         | 単位 |
|-----------------------------|---------------------|---------------------|------------------------------|------------------------------|----|
| $V_u$ :ターミネーション抵抗           | $V_{DDQ}/2 (=0.75)$ | $V_{DDQ}/2 (=0.75)$ | $V_{DDQ} (=1.5)$             | $V_{DDQ} (=1.5)$             | V  |
| $V_{ref}$ :リファレンス電圧         | $V_{DDQ}/2~(=0.75)$ | $V_{DDQ}/2 (=0.75)$ | $V_{DDQ} \times 60\% (=0.9)$ | $V_{DDQ} \times 60\% (=0.9)$ | V  |
| Hレベル電位 (DC 最小)              | Vtt+0.4             | Vtt+0.4             | $V_{DDQ} = 0.4$              | $V_{DDQ} = 0.4$              | V  |
| Lレベル電位(DC 最大)               | Vtt = 0.4           | Vtt - 0.4           | 0.4                          | 0.4                          | V  |
| I <sub>OH</sub> (計算値)       | 8                   | 8                   | 8                            | 8                            | mA |
| <i>I<sub>OL</sub></i> (計算值) | <b>- 8</b>          | - 8                 | - 48                         | - 48                         | mA |

つまり、HSTLの規格上では $0.4 \sim 1.5 V$ までの1.1 Vp-pという、 $V_{DDO}$ のほぼ全域にわたって電圧振幅をします。

このクラスでは、HSTL信号規格のうえで、外乱ノイズやクロストークノイズなどのノイズマージンを考慮して、あえて低電圧振幅を期待せずに 1.8V の LVCMOS のように高いノイズ耐性が必要な場合に使用されるインターフェースです。

#### ▶ HSTL クラス 4

HSTLクラス $_3$ と同じ $V_{tt}$ や $V_{ref}$ で、信号経路の構成がHSTLクラス $_2$ と同じものです。クラス $_3$ 同様に、高いノイズ耐性が期待できます。

これらのクラスによる違いをまとめたものを**表5**に示します. 信号経路の構造は、すでに説明した SSTL のものとかわらず、 リファレンス電圧とドライバ/レシーバに対する駆動電圧が違 うだけなので、この機会に双方の規格を頭の片隅に置いておく のもよいかと思います.

#### GTL/GTL+/AGTL/AGTL+

このインターフェースは、Xeroxが低電圧駆動の高速なロジックインターフェースとして1991年に考案されたもので、発明者のBill Gunning の名前にちなんで、GTL(Gunning Transceiver Logic:ガンニングトランシーバロジック)と名づけられました。GTLは、数百 MHz の高クロック周波数帯域におけるデータ転送が必要な通信機器で、筐体内におさめられたバックプレ

#### 〔表 6〕 GTL/GTL+/AGTL/AGTL+ の特性表

| 信号名                     | GTL  | GTL+  | AGTL | AGTL+ | 単位 |
|-------------------------|------|-------|------|-------|----|
| $V_{TT}$ ターミネー<br>ション電圧 | 1.20 | 1.50  | 1.25 | 1.50  | V  |
| V <sub>REF</sub> 基準電圧   | 0.80 | 1.00  | 0.83 | 1.00  | V  |
| 電圧振幅                    | ± 50 | ± 200 | ± 20 | ± 200 | mV |
| 終端                      | 必須   | 必須    | 必須   | 必須    | _  |

ーンや CPUと I/O 間を接続するインターフェースとして利用 されています。

GTL は SSTL や HSTL と同様に、 $V_{ref}$  を使って信号レベルを判定する、オープンドレイン方式の信号インターフェースです。 $V_{TT}$  電圧 = 1.2V、 $V_{ref}$  = 0.8V で、SSTL クラス 3 や 4 に似ていますが、信号振幅はさらに低く、 $V_{ref}$  に対して  $\pm$  50mV (=100mVp-p) となっています。

そして、インテル社はGTLをベースに、Pentium Proのバスとして、クロック 66MHz/8 デバイスがサポートできるよう、 $V_{TT}$ =1.5V、 $V_{ref}$ =1.0V、電圧振幅を $\pm$ 200mV に変更したGTL+を開発しました。そして、この信号インターフェースをシステムバスの特許として成立させて Pentium II まで使用されました。

その後、インテル社は Pentium IIIのシステムバスとして、GTL+の規格を元に、オープンドレインの出力ドライバに補正、つまりアシスト機能を追加した AGTL(Assist GTL)/AGTL+インターフェースを採用し、現在に至っています(表6).

#### ディファレンシャルインターフェース編

#### ECL/PECL

• 古くから利用されている高速インターフェース

ECL は占くから利用されている信号インターフェースで、非常に長い歴史があります。もっとも、コンピュータの世界で「非常に長い歴史がある」と書いたとしても、たかだか20年~30年程度のことですが、筆者が生まれた1970年代前半の大型コンピュータでは、すでにこの信号インターフェースが使われていました。

執筆の関係で、当時の資料をインターネットで検索したところ、すでに 1975 年時点で、ECL デバイスの IC 内部におけるゲ

ート間遅延時間は  $500ps \sim 700ps$ , チップ外側でも 2ns という速度の ECL デバイスが使われていたようです.

#### • ECLとは

ECLとは、Emitter-Couplered-Logic (エミッタ結合型論理回路)の頭文字をとったものであり、バイポーラトランジスタで回路が構成されています。ECL回路の基本は、OR/NORゲートです。TTL回路の基本がNANDゲートであることでは、基本論理が違う点に気をつけなければなりません。

図12(a)は、OR/NOR型ゲートロジックの基本回路を表したものです。この回路は、米国モトローラの開発したMECL (Motorola-ECL) 製品群の中の、10Kファミリと呼ばれるもの

〔図 12〕 ECL の回路



で、ECL 登場初期の回路です. 型番は MC10xxx となってい ます.

基本構成はトランジスタで構成された差動アンプで、ECLの 基本動作はトランジスタの非飽和領域を使った差動アンプの動 作そのものです 注.

片側の差動アンプの入力側には、コレクタとエミッタが結合

された複数のトランジスタが接続され、そのベースは外側に出 力されています. これが ECL の入力ピンです. 差動アンプの片 側はコレクタに印加される電圧から 1.29V 下がった定電圧が接 続されます.

回路図右端は、この-1.29Vを生成するためのレギュレータ 回路です。10Kファミリは、抵抗と2組のダイオードにより電

注:TTLや CMOS は電源電圧フルに振幅を振って飽和させた「スイッチング動作」だが、ECLでは $V_{BE}$ - $I_B$ 特性の急峻な電流カーブを有効に使った「アナログ動作」 である.詳細は後述するが、十分なゲイン(増幅度)をもったトランジスタであれば、この非飽和領域を使うことで、高速なスイッチングを行える.

## Column 3

消費電力についての考察

低電圧で駆動する時代になると、消費電力のことも考慮しておか ねばなりません。LVTTLやLVCMOSインターフェースでは、ど のようなときに電力を消費するのでしょうか。

LVTTLを構成する回路を、基本構成を忠実に考えてトランジスタで構成されたものと想定して考えてみます。

トランジスタの ON 状態、または OFF 状態を制御するためには 微弱ながらも電流がトランジスタのベース-エミッタ間に電流  $I_b$  が流れなければなりません。そして、この電流が流れることで、コレクタ-エミッタ間に電流  $I_{ce}$  が流れるか流れないかが定まります(図 F)。トランジスタが OFF 時であれば  $I_b$  は流れませんが、ON 時であれば  $I_b$  は必ず必要であり、その電流量は数  $\mu$ A ~数十  $\mu$ A です。

次は、LVCMOS デバイスを構成する回路を、MOS-FET で構成されたものを考えてみましょう。MOS-FET の場合には、すべてエンハンスメント型の FET で動作の説明ができます。MOS-FET の動作は、ゲート-ソース間の電圧  $V_{ss}$  が印加されることで、ドレイン-ソース間に電流  $I_{dds}$  が流れます。N チャネル MOS-FET の場合、 $V_{gs}$  の電圧が高ければ高いほど  $I_{dds}$  が流れますし、逆に  $V_{gs}$  が oV であれば  $I_{dds}$  は流れません。これにより、ドレイン-ソース間で oM/OFF を切り替えます。P チャネル MOS-FET は、この動作が逆です(図 oG)。

そして、トランジスタとは違ってドレイン-ソース間が ON のときに必要な、ゲート-ソース間に流れる電流= $I_{gs}$ は nA、もしくは pAオーダ、場合によっては fA(フェムトアンペア)オーダまで小さいものもあります。

#### 〔図F〕トランジスタの動作

| 名前       | 構造                                                            | 静特性                                                                                                                                                               |
|----------|---------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NPN<br>型 | コレクタ(C)<br>***<br>***<br>***<br>***<br>***<br>***<br>***<br>* | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                            |
| PNP<br>型 | コレクタ(C)<br>・                                                  | $ \begin{array}{c c} V_{CE} & [V] \\ -4 & -2 \\ -5 & -3 & -1 \\ \hline 0 & & & \\ \hline I_B = -0.1 \text{mA} \\ -0.2 & & & \\ \hline -0.3 & & & \\ \end{array} $ |

スイッチとして素子を利用した場合, MOS-FET で必要な電流はトランジスタにくらべて, 1/1000以下の微小なものです(あくまで, 個別半導体で構成した場合を想定).

よって、トランジスタで構成された LVTTL インターフェースの場合には、"H"が"L"かのいずれかの一定の信号レベルに保つため、いくつかのトランジスタを駆動するわけですが、この際に必ず電流が流れ続けるわけです。

それに対して CMOS デバイスは、論理の確定時点ではほとんど 電流は流れません。よって、トランジスタ構成の LVTTL と違って LVCMOS は消費電力が非常に小さいのです。

とはいえ, "H"→"L"または"L"→"H"にレベルが変更する動作状態はどうでしょう. 結論をいうと, LVTTLもLVCMOSも, この状態に電力消費をします.

このほかにも、トランジスタや FET 素子はある程度の容量性負荷をもっており、前段の素子から後段の素子をドライブするためにこのような容量性負荷に対するチャージのための電流が必要になることも見逃せません。

これらの事情から、低消費電力をめざしているデバイス、とくに ディープサブミクロンプロセス世代では、

- (1) トランジスタのスイッチング速度を上げる
- (2) スレッショルド電圧に対する感度を上げる
- (3) スイッチングデバイスの負荷容量を小さくする などの対策を施します.
- (1)と(2)を組み合わせることで、スイッチ切り替えの瞬間の貫通電流を減らせます。また、とくにゲインを上げるとミラー効果で見かけ上の容量性負荷が増えるため、ゲインを抑えるためにシリコンに金を混入(ゴールドドーピング)してゲインを下げたり拡散膜を極限まで薄くするといった方法を採ります。

以上のような努力は、各半導体メーカーではあたりまえのように 行っており、今日の高性能な半導体製品があるのです。

#### 〔図G〕FETの動作



#### 〔表7〕ECL特性表

| パラメータ                                        | F                 | ECL-10K/10H |        | ECL-10E/100E |        |        | LVPECL-MC100LVEL |      |        | 単位    |
|----------------------------------------------|-------------------|-------------|--------|--------------|--------|--------|------------------|------|--------|-------|
|                                              | 最 小               | 標準          | 最 大    | 最小           | 標準     | 最大     | 最 小              | 標準   | 最大     | 平 174 |
| $V_{CC}$ :上側電源電圧                             | - 0.05            | 0.00        | 0.05   | - 0.05       | 0.00   | 0.05   | 3.14             | 3.30 | 3.47   | V     |
| V <sub>FE</sub> : 下側電源電圧                     | - <sub>5.46</sub> | - 5.20      | - 4.94 | - 5.25       | - 5.00 | - 4.75 | - 0.05           | 0.00 | 0.05   | V     |
| V <sub>u</sub> : ターミネーション電圧                  | - 2.19            | - 2.09      | - 1.99 | - 2.19       | - 2.09 | - 1.99 | 1.14             | 1.30 | 1.47   | V     |
| V <sub>IH</sub> : H レベル入力電圧                  | - 0.96            |             | - 0.81 | - 1.16       |        | - 0.88 | 2.14             |      | 2.42   | V     |
| $V_{\!\scriptscriptstyle I\!\!L}$ : Lレベル入力電圧 | - 1.85            |             | - 1.65 | - 1.81       |        | - 1.47 | 1.49             |      | 1.85   | V     |
| <b>H</b> <sub>H</sub> : H レベル入力時リーク電流        | 50.00             |             |        |              |        | 150.00 |                  |      | 150.00 | μΑ    |
| <b>V</b> <sub>OH</sub> : <b>H</b> レベル出力電圧    | - 0.96            |             | - 0.81 | - 1.03       | - 0.95 | - o.88 | 2.27             | 2.35 | 2.42   | V     |
| $V_{OL}$ : Lレベル出力電圧                          | - 1.85            |             | - 1.65 | - 1.81       | - 1.75 | - 1.62 | 1.49             | 1.60 | 1.68   | V     |

注意: ECL-10E/100E は  $V_{CC}$ =5,0V,  $V_{EE}$ =0Vで、5V-PECLとしても使用可能、その場合の $V_n$ は3,00V/50 $\Omega$ ターミネーションを原則とする.

流値を決め、そして $V_{EE}$ から 1.29V の電圧を作るためのエミッタ抵抗値が決まるような、簡易的なレギュレータ回路になっています。

そのため、電圧変動や温度変化による 1.29V の定電圧特性が安定しないという問題があるため、こののちに 10H や 100H などの新しい回路構成をもつ ECL デバイスに切り替わっていきました [図 12(b)].

なお、MECL-10Kファミリと区別するために、型番はMECL-10Hxxx やMECL-100Hxxx となっています。

#### PECL

ところで、ECL デバイスを使う場合には、通常よく使う+5V/oV のような正電圧ではなく、0V/-5.2V(ECL-10K)や0V/-4.8V(ECL-10H/100H)のような負電圧が必要です。

そのため、一般的に使用される正電圧駆動のTTL/CMOSデバイスとの混在設計時において、高速とはいえ負電圧が必要なECLは敬遠されました。それを受け、後に正電圧で駆動するECLデバイスが登場しました。これがPECLデバイスです。なお、一般的にPECLというと、Positive-ECLという名前で呼ばれますが、1991年に筆者がはじめてPECLを使ったときにはPseudo-ECL、つまり疑似ECLと呼ばれていました。

ちなみに、ECLデバイスは仮に 10K ファミリでも、+5V/oV の TTL レベルで使用が可能です。レベルが 5V 系の TTL や CMOS と異なるだけで、ちゃんとこれらのデバイスを駆動できます。筆者は 100H ファミリを無理やり 5V で駆動し、出力を高速の PNP トランジスタを使ったレベルシフタで TTL レベルまで落として使用した実績があります。出力レベルの動作点さえしっかりおさえておけば、いろいろな使い方ができるのが ECL でした。

#### • LVPECL

そして、今日現在では、5V系正電圧で動くPECLに対して、3.3V系正電圧で動作するローボルテージ版のLVPECL製品が商品化されています。

米国モトローラでは、ECLinPS(エクリンプスと呼ぶ)ファミリという名前で出荷されており、ゲートロジック、400MHz~800MHzクラスのPLLクロックシンセサイザ、クロックディス

トリビュータ (クロック分配デバイス) や LVPECL  $\rightarrow$  LVTTL レベルシフタなどのデバイスファミリが出荷されています.

また、この LVPECL インターフェースは、昨今の高性能 FPGA でも使用できるようになっており、LVPECL は数百 MHz から GHz の一歩手前程度までの伝送方式として、一般的な信号インターフェースになるのではないでしょうか.

#### ● ECL/PECL/LVPECLの特性

表**7**は、ECL/PECL/LVPECLの各ファミリごとのレベルを示したものです。

信号の振幅はおよそ 800mV 程度であり、レベルが反転した 2 本の差動信号で伝送されます。 ECL 系の出力段は、単純なトランジスタのエミッタ端子がそのまま外に出力された形になっていることが特徴であり、外側には必ず  $V_{tt}$  (ターミネーション電圧) との間に  $R_{t}$  (ターミネーション抵抗) を実装することが必要です。

このターミネーション抵抗は、一般的に ECL/PECL/LVPECL ともに  $50\Omega$  に設定されており、伝送線路の特性インピーダンス  $Z_o$ もこの  $R_c$  と同様の  $50\Omega$  でのインピーダンスコントロールが 推奨されます.

ターミネーション抵抗が接地する $V_n$ は、 $V_{cc}$ 電圧から 2.0V低い電圧に設定されます。ECL の場合には- 2.0V が、5V 駆動の PECL の場合には 3.0V が、3.3V 駆動の LVPECL の場合には 1.3V がターミネーション電圧となります。これらの電圧は  $V_{cc}/V_{EE}$ 電圧以外にリニアレギュレータや DC/DC コンバータなどの別電源で作成して供給しなければならない点が面倒なところです。

なお、トランジスタのエミッタが単純に外側に出力されているだけなので、ターミネーション抵抗をつけないと、電圧振幅 は発生しないので注意が必要です.

また、エミッタが単純に外に出されているだけなので、ドライブ能力が足りないと思ったときには、複数のゲートを束ねてドライブ能力を稼ぐことができ、数十ものデバイスが連なったハイファンアウト(高負荷)状態を駆動する際には有効な方法です。もっとも、最近のLVPECLでは、このようなアプリケーションノートは見られなくなり、ハイファンアウト対応のバッ

#### 「図 13 CML の 同路



ファ(ディストリビュータ)の使用を推奨しているようです.

#### • 消費電力

ECL/PECL/LVPECLは、内部構成がバイポーラトランジスタで作られているために、常時電流を流しておかなければならないという仕様になっています。

最近は CMOS プロセスに移行していますが、10K や10H ファミリはバイポーラトランジスタを差動ペアの入力段に用意しているので、トランジスタに流れ込むバイアス電流も CMOS デバイスの比ではありません。やはり、ここでも電流が流れてしまいます。

また、振幅そのものは 800mV と小さいのですが、 $50\Omega$  のターミネーション抵抗は TTL/CMOS のようなシングルインターフェースにおけるプルダウン抵抗と同じで  $V_n$  電圧に接続されているために、" H"レベルでも" L"レベルでもこの抵抗でかなりの電力が消費されてしまいます。

これらの理由から、レベルが固定された状態でも電力が消費され、「ECL は熱い」、「ECL は大電力食いだ」とよく言われます。

実際、ECLを採用したシステムは冷却系にも気配りが必要であり、メインフレームなどの大型汎用コンピュータでは循環液体冷却型の冷却システムを装備しているものも少なくありません。

低電圧/低消費電力システムの需要が高まる現代社会においては、いささか ECL/PECL/LVPECL は占いデバイスであるために、採用が敬遠されがちのようです。低電圧/低消費電力が要求される昨今では、ECL構成はたしかに厳しい状況であり、今後は CML や LVDS に徐々に切り替わっていくと予想されます。

#### **CML**

#### • CMLとは

CMLとは、Current-Mode-Logic(カレントモードロジック)の頭文字をとったものです。じつは、筆者はこの執筆を行うまで、CMLはバイポーラトランジスタのコレクタをイメージした、Corrector-Mode-Logic(コレクタモードロジック)のことだと思っていました。CMLの回路構成をみると、筆者がそう思っていた理由がすぐわかると思います。

図13に、FETで構成した CML 回路を示します。これからわかるように、CML は差動アンプのコレクタ側につながるパスが出力端子となっており、次段の入力端子に接続されます。そして CML では、外部で $V_{cc}$ 電圧と接続されたターミネーション抵抗が必須になります。

別の言い方をすれば、差動アンプ部が NPN バイポーラトランジスタ、または NMOS-FET で構成されているために、" L " レベルに落とす能力はあっても" H "レベルに持ち上げる能力は基本的にないので、 $V_{cc}$ 電圧に接続された抵抗が必要になるということなのです。

ただし、最近の CML デバイスではあらかじめ  $V_{cc}$  電圧と差動アンプ部の間に抵抗が入ったものもあります。これは、外側の抵抗がなくとも電流経路が確保されて出力電圧を得ることができる利点があります。ただし、この場合でも超高速帯域で利用される CML は一般的に伝送線路の特性インピーダンスとマッチングさせるために、内蔵された抵抗または特性インピーダンスと同等の抵抗を外部に接続します。

ここで, 前項の ECL の解説で紹介した回路構成 (図 12(b)) と

## 特集 高速バスシステムの徹底研究

〔表 **8**〕 第 **2**章で紹介する光モジュール の特性表

| パラメータ                                 | Opto0           | Cube-LVDS = | ニード  | OptoC  | 単位   |                |      |
|---------------------------------------|-----------------|-------------|------|--------|------|----------------|------|
|                                       | 最 小             | 標準          | 最大   | 最 小    | 標準   | 最大             | 中 1位 |
| $V_{cc}$ :上側電源電圧                      |                 | 3.30        |      |        | 3.30 |                | V    |
| V <sub>EE</sub> : 下側電源電圧              |                 | 0.00        |      |        | 0.00 |                | V    |
| $V_{cm}$ :コモン電圧                       | $V_{EE} + 0.85$ | 1.20        | 3.50 |        |      |                | V    |
| V <sub>aff</sub> :差動電圧                | 0.20            | 0.80        | 1.90 |        |      |                | V    |
| 入力容量                                  | 1.00            | 1.30        | 1.60 | 1.00   | 1.30 | 1.60           | pF   |
| $V_{\mathit{OH}}: \mathbf{H}$ レベル出力電圧 |                 |             |      | 2.00   |      | $V_{CC}$ + 0.3 | V    |
| $V_{oL}$ : Lレベル出力電圧                   |                 |             |      | - 0.30 |      | 0.80           | V    |

見比べてみましょう。出力トランジスタの  $Q_4/Q_5$  のベース入力につながる差動アンプのコレクタ端子が CML の出力ピンであり, $Q_4/Q_5$  トランジスタ自身は受け側の入力差動アンプそのものであることが見て取れます。つまり,CML は $V_{cc}$  から差動アンプのコレクタにつながる電流経路が外側に依存したものであり,ECL の回路と比較しながら動作を理解することができます。

もっとも、ECLの場合は電流出力型であり、CMLの場合には電流引き込み型である点が違いますが、その違いは差動アンプの先に出力トランジスタがあるかないかによる違いからきます。

#### • RS-422 などでも使われている

さて、CML も ECL と同様にたいへん占くから使われています。平衡式の差動インターフェースである RS-422 は、 ± 20mA の電流駆動方式を採用した CMLです。 RS-422 では信号レベルとして電圧をやりとりしているのではなく、ドライバ側デバイス内の差動アンプによる引き込み電流の違いによりレベル判定を行い、レシーバ側の終端抵抗によりレシーバ側の入力ピン電位が決定されます。

RS-422 の場合、終端抵抗は  $100\Omega$  であり、筆者の手元にある 1981 年の資料を見るかぎり、この当時で伝送線配線長は最大で

## Column 4

原理を理解すれば応用も効く

CMLで説明しましたが、CMLインターフェースだからといって、ドライバ/レシーバの双方がCMLインターフェースでなければならないということはありません。最新のFPGAがこれだけいろいろなインターフェースに対応してくると、本来なら異なるインターフェースでありながら、抵抗を付けたり電圧を少し変更するなどの工夫次第で、電気的に問題なく接続できてしまうことがあります。

ディジタル設計者の場合、厳格な DC スペックや振幅電圧 について懸念される方が多いように見受けられます. 詳細ま では追求しなくとも回路の駆動原理をある程度の範囲で知っ ておけば、諸般の事情で推奨回路を採用できなくても、問題 なく動く回路を実現できるものです. 臨機応変にデバイスを 使いこなそうではありませんか! 4000 フィート (100kbps 時), 伝送速度は 10Mbps (15 フィート時) という速度をたたき出しています.

ちなみにこの時代, 1979年に登場した MC68000の 4MHz版が日本で流通し始めたころなので, 当時としては RS-422 は非常に高速な通信手段の一つだったのです.

#### • 通信分野で多用される CML

そして、この CML インターフェースは、いまや通信分野で はなくてはならないインターフェースの一つです

第2章で解説する光デバイスの送信側/受信側デバイスのインターフェースには、CML方式を採用するものが非常に多く見られます。さらにいえば、光ファイバによるデータ通信のプリアンプの入出力は、総じてCML方式である場合が多いのですが、その理由としては回路構成が異常なほど(?!)に簡単であるからではないでしょうか。

回路構成が簡単ということは、信号の伝達経路が短く、このため高速なスイッチングにも対応することが可能となります。 ECLも十分に単純な構成なのですが、CMLは出力トランジスタさえも省いた回路構成なので、さらにこの出力トランジスタ段の分だけ速くなります。

#### CMLの特性

CML は、ターミネーション抵抗などもある程度自由に決められます。ECL の場合には、ターミネーション電圧は $V_{CC}-2V$  近辺 (回路上では正確には 2.09V)、そしてトランジスタのエミッタ出力ピン上に電圧振幅を発生させるためにはこのターミネーション電圧に接続されたターミネーション抵抗が必要であり、その抵抗値として  $50\Omega$  が強く推奨されています。実際、この値でなければ ECL の回路経路として成り立たないというのが現状です。

それと比較して、CMLでは差動アンプそのものを外部 $V_{cc}$ と ターミネーション抵抗に頼っているために ECLのような規則はなく、単純に電流経路さえ確保すればあとは次段の差動アンプの動作点の確保だけで動いてしまいます。

抵抗値も  $100\Omega$  だったり、 $50\Omega$  だったり、伝送線路の特性インピーダンスに応じて決定でき、自由度がとても高くなっています.

また、CMLの入力電圧範囲は、差動アンプさえ駆動できるのであれば、何Vp-pかなどというのもじつはあまり重要でないスペックの書き方がされています。

表8は、第2章で解説する光モジュールの電気的特性をまとめたものです。表中の入力差動電圧 (Input Differential Voltage) の項目に注目してください。最小 200mV から最大 1900mV まで、広い範囲で受け付けます。あわせて、コモン電圧 (Voltage Common Mode Range:動作時の中心電圧) をみても、 $V_{EE}$  から 850mV 以上 (このデバイスは、通常  $V_{EE}$  はグラウンドレベル/oV で使う) であれば、 $V_{CC}$  を超えても使えてしまいます。

「何という無節操な電気的特性条件なのか!」と思われるかもしれませんが、この光モジュールにかぎらず、ほかの光モジュールも入力側のインターフェースが CML であればこんなものなのです。

実際、この回路は3.3V 駆動で動く LVPECL インターフェースを直結しても正常に動作します。LVPECL の出力電圧範囲/コモン電圧と CML の入力電圧範囲/コモン電圧が正しく一致します。

では、出力側はどうかというのをみても、この光モジュールのレシーバデバイスの規格を見ると、100 $\Omega$ 終端時には7mA~11mAとなっています。電圧振幅は、最大で800mVというのもわかるでしょう。出力電流をおおよそ8mA程度で計算すると、100 $\Omega$ 終端時には800mVの電圧が発生すると考えられます。

さらに、レシーバデバイスの差動出力電位は CML の差動アンプに供給する  $V_{CML}$  電圧から 500mV と規定されていて、コモン電圧を中心に 800mVp-p の振幅を取ることになります.

よって、CML インターフェースをもつこのデバイスの出力を、たとえば 3.3V LVPECL インターフェースレベルにもち込むのであれば、 $V_{CML}$  に対して LVPECL のコモン電圧点である 2.0V から 500mV 程度持ち上げた電圧、つまり 2.5V を供給すれば、電圧レベルは" H "レベルのときに 2.4V、" L"レベルのときには 1.6V となり、LVPECL インターフェースの仕様を満たすことができます。

#### **LVDS**

#### • LVDSとは

LVDS は、PCI Express (第4章参照) や Fibre Channel のようなパソコン周辺機器への応用から、最新マイクロプロセッサや FPGA のバスインターフェースの一つとして、いまもっともホットな信号インターフェースの一つです。

LVDSとは、Low-Voltage-Differential-Signal の頭文字をとったもので、直訳すると「低電圧振幅/差動インターフェース」です。

とはいえ、低電圧振幅とだけいってしまうと、何に対して低電圧なのか?という部分が不明なので、このLVDSもSSTLやHSTLと同様に規格が規定されています。

ただし、LVDSはちょっとややこしく、二つの規格団体が規格書を出しているので、若干混乱するのではということを筆者

#### 〔図14〕LVDSの結合容量



は懸念しています.

#### ▶ ANSI/TIA/EIA-644 (LVDS) 規格

LVDSを汎用インターフェースとして利用しようという意図の元に制定された規格です。電気的特性のみが規定されており、コネクタ形状や伝送線路の方式などのどちらかというと機械的な特性は規定されておりません。

#### ▶ IEEE-1596.3

この規格は、もともと LVDS を目的に作られたものではなく、コンピュータシステムのアーキテクチャ規格の中の「SCI: Scalable Coherent Interface」という伝送路規格の一つに、LVDS インターフェースが組み入れられています。

ここでは ANSI/TIA/EIA-644 に基づいた解説を行います.

#### • LVDS の特徴

差動インターフェースのなかでも、この LVDS は数百 Mbps から数 Gbps の伝送に対応することが可能な、小信号振幅信号インターフェースの一つです。電圧モードでの入出力を行うのではなく、電流モードドライバによる信号レベルの伝送を行い、小振幅電圧を差動インターフェースで出力するために、高速でかつ低ノイズである点が特徴です。

この電圧振幅が小さいということは、スルーレートが支配的 になる高クロックでの伝送では重要な要素です。また、それは 同時に消費電力を少なくできます。

また、基本的に隣り合う、もしくは隣接する1対の平衡(2本で1組の対の信号)ラインで伝送される差動インターフェースは、信号伝送時に発生する磁界が相殺されます。このため、もともと外部へ発生するノイズ量が少ない差動インターフェースですが、発生するノイズは低電圧振幅でさらに小さくなります。

低電圧振幅であると、LVTTLやLVCMOSのようなシング ルエンドインターフェースではよく耳にするノイズマージンに 対して懸念される方もいるかと思います.

じつは、筆者もシングルエンドではこれに悩まされたのですが、差動インターフェースの場合には、それほど深刻になることもないと考えます。というのは、LVDSは電流の方向で信号レベルが決まるので、仮に電源電圧が多少狂っても平衡ライン上の差動信号には影響はありません。

#### 〔図 15〕LVDS 出力側ドライバの回路図



#### 〔図 16〕LVDS 出力側ドライバの動作



(b) SW2とSW4がONになり SW2とSW4がOFFになった場合 SW1とSW3がOFFになった場合

3.5mA

さらにいえば、LVDS は送信側/受信側の回路共に、TTLの 5.0V 電源電圧, PECL の 3.3V 電源電圧というような, 特定の 電源電圧に依存していません.

つまり、2.5V電源システムや1.8V電源システムなどの低電 圧駆動システムに移行しやすく、かつ特性を損なうことなく信 号の伝送ができるという利点があります.

また, 自身からのノイズ発生量が少ないということは, 隣り 合う LVDS 信号線対に与える影響。つまりクロストークの発生 も小さくなります。もしクロストークが乗ったとしても、この クロストークノイズは差動ペアの両側に同様な強度で乗ること になり、結局このノイズはキャンセルされてしまい、影響はな くなります(図14, 前頁).

#### LVDS 回路の構成と動作解説

LVDS は、MOS-FET で回路を構成することができます.

ECL/PECL/LVPECL や CML などの回路で使われている NPN-PNP バイポーラトランジスタと異なり、MOS-FET (モノ リシックトランジスタ)で構成できるということは、昨今の CMOS プロセスの進化と相まって製造が楽であり、たいへん大 きなメリットとなります.

というのも、すでにご承知のとおり CMOS プロセスは Complex-MOS という名前からもわかるとおり、NMOS-FET と PMOS-FET の組み合わせで作られるものであるため、その製 造工程をそのまま LVDS の入出力回路に適用できるというわけ です

図15 に、NMOS-FET と PMOS-FET で構成した LVDS の出 力側ドライバの回路図を示します. 入力側レシーバの直前には 100Ωの終端抵抗が接続されます。100Ωの終端抵抗の位置を

| 信号名    | LVTTL   | LVCMOS               | SSTL2-クラス 1       | LVPECL         | LVDS         | 備考                   |
|--------|---------|----------------------|-------------------|----------------|--------------|----------------------|
| 動作電圧   | 3.3V    | 3.3V                 | 2.5V              | 3.3V           | >2.5V        | SSTLや差動はドライバの電源電圧とする |
| 動作中心電圧 | _       | _                    | 1.25V             | 2.0V           | 1.25V        |                      |
| Hレベル電位 | 2.0V    | $V_{CC} \times 90\%$ | 1.65V             | 2.35V          | 1.425V       | 常温・最小値               |
| Lレベル電位 | 0.8V    | $V_{CC} \times 10\%$ | 0.85V             | 1.60V          | 1.075V       | 常温・最大値               |
| 電圧振幅   | 1.2V    | 3.3V                 | 400mV-800mV       | 750mV          | 350mV        | SSTL2 はおおよそを表す       |
| 終端     | 不必要     | 不必要                  | 必須                | 必須             | 必須           | LVTTL/LVCMOSでは一般例を表す |
| 最大伝送速度 | 166Mbps | 133Mbps              | 333Mbps           | 800Mbps        | 2Gbps        | 筆者の設計目安              |
| 用途     | - 舟殳    | 一般                   | DDR/DDR-II<br>メモリ | システム<br>クロック分配 | 高速伝送<br>線路部位 | 筆者設計での主たる用途を示す       |

MOS-FET スイッチ群の中間にもってきてサンドイッチすると、アルファベットの"H"に見立てられることから、このような回路構成を「Hブリッジ」といいます.

この H ブリッジ内の縦に並んだ FET をスイッチに置き換え、中心の電圧を検討してみると、もっと回路動作が分かりやすくなります (図 16). この回路は  $SW_1$  と  $SW_3$ , ならびに  $SW_2$  と  $SW_4$  の組み合わせのいずれか片方しか ON にならないしくみです。これが大前提となります。

ではまず、SW1とSW3がONになり、SW2とSW4がOFFになった場合を想定してみましょう〔図 16(a)〕、電流は $V_{cc}$ からSW1を経由して、抵抗素子のa端子に流れます。そして、抵抗のb端子 $\rightarrow$ SW3を経由してグラウンドにつながります。つまり、 $V_{cc} \rightarrow$ SW1 $\rightarrow$ 抵抗素子 $\rightarrow$ SW3 $\rightarrow$ グラウンドというパスになります。このときの抵抗素子のa端子とb端子を見ると、a端子の電位 $V_{Ra}$ は $V_{Cc}$ 電圧、そしてb端子の電位 $V_{Rb}$ はグラウンド電圧となります。

次に、 $SW_2$ と $SW_4$ が ON になり  $SW_1$ と $SW_3$ が OFF になった場合を想定してみましょう [図 16(b)]。電流の流れは、今度は  $SW_2$ を経由して抵抗素子の b端子に流れます。そして、抵抗の a端子 $\rightarrow SW_4$ を経由してグラウンドにつながります。まとめると、 $V_{cc} \rightarrow SW_2 \rightarrow$ 抵抗素子 $\rightarrow SW_4 \rightarrow$ グラウンドというパスです。抵抗素子の両端の電圧を見てみると、先ほどの例とは違い、a端子の電位 $V_{Ra}$ は GND 電圧、そして b端子の電位 $V_{Rb}$ は  $V_{CC}$ 電圧になります。

まとめると,

- ullet SW1/SW3 が ON のときは,抵抗素子の  ${
  m a}$  端子電位  $V_{\it Ra}$  は  $V_{\it CC}$
- $\bullet$ SW2/SW4がONのときは、抵抗素子のa端子電位 $V_{Ra}$ はグラウンド

となり、スイッチの開閉状態に応じて、信号レベルが反転したことになります。

これをもう一度**図 15** にあてはめて考えてみましょう.  $V_{cc}$  およびグラウンドプレーンと MOS-FET で構成された Hブリッジ 回路の間には定電流源があります.  $V_{cc}$ 側につながるのがソース側定電流源, グラウンド側につながるのはシンク側の定電流源です.

LVDSでは、この定電流源で生成される電流を四つの MOS-

FETで構成されたスイッチにより、ソース側の定電流源から電流をターミネーション抵抗に流すことで、ターミネーション抵抗の両端に電圧を発生させ、受信側ドライバに内蔵された差動アンプがその値を読み取ってレベル判定を行います.

ソース側定電流から送出された電流は、ターミネーションを 経由して、再度送信側ドライバ内に戻って、シンク側定電流源 に流れ込みます.

これらの動きは  $Q_1$  と  $Q_3$ 、 そして  $Q_2$  と  $Q_4$  の MOS-FET でその電流方向が制御され、ターミネーション抵抗に流れる電流の向きを制御して、" H "レベルか" L "レベルかを決めているということなのです。

ANSI/TIA/EIA-644 規格では、定電流源が生成する電流値はおよそ 3.5mA です。推奨のターミネーション抵抗値は  $100\Omega$  となっているので、この抵抗器の両端に発生する電圧は 35omV となります。

そして、ターミネーション抵抗のある 1点を a点とみて、a点から b点の電圧を減算し、その電圧が正であれば" H"レベル、oVであれば" L"レベルということになります。

なお、 差動ペアで構成された配電線路の特性インピーダンス  $\mathbf{Z}_{0}$  が  $100\Omega$  である場合にインピーダンスマッチングすることを 想定し、ターミネーション抵抗値の  $100\Omega$  が決められています.

あわせて、LVDS ポートを実装した FPGA や ASSP デバイス なども、レシーバとドライバの特性は通常  $100\Omega$  のターミネーション抵抗に合わせている場合がほとんどですから、基板設計をする際には、特性インピーダンスも仕様どおりにあわせたほうがよいでしょう.

\*

最後に、**表9**に本章で解説したシングルエンドとディファレンシャルインターフェースの比較をまとめておきます.

#### 参考文献

1) 夏谷 実,「FPGA による高速多ビットのデータ転送 ASIC プロトタイプシステム(KM-1)による実現」, EDS Fair 2003 出展者セミナー プレゼンテーション資料, (株) エスケーエレクトロニクス

いくら・まさみ 来栖川電工(有)

# パラレル光モジュールによる デバイス間/ボード間通信の現状

小林雄祐

これまで、光ファイバを使った通信は、非常に長距離のデータ通信や、ノイズの多い環境などで使われてきた。ギガビットクラスの Ethernet や IEEE1394.b などにも光ファイバを使ったものがある。その高速化の流れが、近距離であるバックプレーンなどの筐体内や基板間の接続、さらには同一ボード上でのデバイス間データ伝送にも使われようとしている。ここではデバイス間/ボード間の光化の現状と、それを実現する小型の光モジュールについて解説する。 (編集部)

## **1** なぜ光配線なのか

半導体技術の進歩により LSI に求められる I/O スピードもますます加速され、従来の多ピンによるパラレル信号から、高速シリアルによるデータ伝送が主流になりつつあります。

ボード間,デバイス間の高速シリアル伝送に使用されるICとして一般的なのは、SerDes (Serializer/Deserializer)と呼ばれるICで、通信ICベンダ各社からさまざまな帯域をサポートする製品がすでにリリースされています。

筆者の会社では、PMC Sierra 社の SerDes 製品とあわせ、SerDes 機能を FPGA の中に盛り込んだ ALTERA 社の StratixGX ファミリを高速シリアル伝送市場に紹介しています。実際に、国内機器メーカーからの SerDes 製品に対する引き合いは非常に多く、今後もこの傾向は続いていくものと思われます。

また、ADSLに代表されるブロードバンドインターネットの 普及により通信機器やストレージ機器の高速化、大容量化が進

#### 〔図1〕電気伝送の限界,光通信路の単距離化



み、すでに一部の装置においては電気バックプレーンがシステム構築のボトルネックとなってきているといわれています.

高速ボード設計において、具体的に設計者を悩ませている課題は次のようなものです。

- 電気信号の減衰
- 消費電力の増大
- 伝送線路解析の複雑化
- 基板層数の増大
- ●同時動作雑音/EMIの深刻化

伝送速度を低いレートに据え置いてI/O数を増やしても、伝送路の配線数やLSIのピン数が増大し、新たな問題を引き起こします。

CPUやメモリバス、ネットワークの高速化に合わせ、装置内のボード間、チップ間配線にも高速化が求められており、光信号によるデータ伝送を実現するという解決策がすでに見逃せない存在になってきているといわれています。

ギガビット単位の高速信号を、一般的な FR4 の基板で 1m以上の距離を安定したアイパターンでデータ伝送するのはやさしいことではありません。実際に、複数本の LVDS 差動信号をコネクタとケーブルでボード間データ伝送を実現しようにも、適切なコネクタが世の中に存在しないという話をよく耳にします。

このような高速ボード設計における技術者の悩みを解決する ため、筆者の会社ではギガビット伝送ボードの設計技術セミ ナーを昨年より数回開催しています。また、セミナーなどに合 わせ、高速電気配線を補完する技術としての多チャネル光モ ジュールによるパラレル光リンクを紹介してきました。

### 2 光配線技術の進歩

光の技術もこの数年で飛躍的に伸びており、高速電気伝送の延長線上にある技術の光がより身近に、手頃になってきています(図1). ここではとくに、現在市場が急速に拡大している最

#### 〔図2〕面発光レーザ トップミラー レーザ ▶ 半導体をウエハと垂直 キャビティ 方向に光を発振するレ \_ +f ▶ 波長帯: 850nm(1.3 ボトムミラー μm, 1.5 μmは開発/ 研究されている段階) ▶ 特徴 • 低い消費電力 ・優れた光出力特性 アセンブリが容易 • 低コスト VCSELウエハ

新の半導体レーザと、電気設計技術者からもっとも質問の多い 光ファイバ、コネクタに関して簡単に説明します.

#### ● 面発光レーザ(図2)

現在、通信路の世界で一般的に使用されている端面発光レーザ(DFB レーザ/FP レーザ)は、レーザチップの端面(エッジ)から光を出力しますが、レーザ基盤面と垂直方向に出力するタイプの半導体レーザを面発光レーザ(VCSEL: Vertical Cavity Surface Emitting Laser、以下 VCSEL)と呼びます。

VCSELは光ビームの放射角が狭く、圧倒的な低電流で動作するため、実際に VCSELを使用して高速シリアル電気伝送を置き換える(補完する)ことを目的にしたさまざまな光モジュールが各社よりリリースされています。

VCSELで製品化されているのは、850nmの波長帯域で作動するもののみが製品化されていて、短波長のレーザといえば850nmのVCSELを指しています。数km以上の長距離光伝送が可能な1310nmや1550nmの波長帯域をサポートするものもさまざまな企業や国内外の大学、研究機関でさかんに研究されていますが、未だに製品化には至っていません。

VCSELは、ウエハに結晶させてできるため、テストをウエハのままで行うことが可能で、歩留まりも従来のレーザより格段に向上しています。つまり、通常長距離伝送に使用されている端面発光レーザに比べると、格段に低コストで生産することが可能になっています。同じウエハに並んだ12個のVCSELをそのまま切り取って、12チャネルの光源としてパラレル伝送に使用することもできます。

#### • 光ファイバ

これは光を通す通信ケーブルで、電気信号を流して通信する メタルケーブルと比べて信号の減衰が圧倒的に少なく、超長距 離、高速でのデータ通信が可能となります。また、光ファイバ を大量に束ねても相互に干渉しません。

光ファイバケーブルは、用途に応じて大きく二つに分けられます。ガラス製で高速転送に対応するが取り回しが難しいシン

#### 〔図3〕MT型コネクタ



グルモード光ファイバ(SMF),プラスチック製もしくはガラス製で転送速度は落ちるが、扱いが簡単なマルチモード光ファイバ(MMF)があります。

#### ▶シングルモード光ファイバ(SMF)

長距離にわたる高速なデータ転送向けで、光ファイバのコアの部分が非常に細いため MMF に比べ折り曲げに弱く、高い加工技術も必要となります。現在の通信装置で標準的に使用されています。

#### ▶マルチモード光ファイバ (MMF)

おもに、LANなどの内部通信に利用されています。SMFに比べ安価で、かつ折り曲げにも強く加工しやすいのが特徴です。 伝送距離はSMFに比べて短いのですが、最近は新世代のMMFも製品化されており、伝送距離もどんどん伸びています(VCSELとの組み合わせで500m以上)。接続作業が容易なのも特徴の一つです。

最近発表されている VCSEL ベースの光モジュールは、MMF に対応したタイプがほとんどで、現在まさに VCSEL と MMF の組み合わせにより低価格で光を使用するアプリケーションがますます増えてきています。

#### コネクタ

光ファイバ用コネクタアダプタには、現在多くの種類があり、数多く規格化されています。単芯コネクタのSC型コネクタなどはもっとも一般的なコネクタの一つですが、最近ではさらに高密度/省スペース型のコネクタが登場し、NTTで開発されて世界標準となったMT型コネクタなど、非常に小型で数十芯のファイバを束ねることができるものも登場してきています(図3).

アクセス網の光化などにおける電柱間ケーブルの接続用や光 モジュールやコンピュータの光接続に用いられるコネクタとし てますます需要が見込まれているようで、コネクタの世界でも 「小型化」がキーワードになり、重要度を増しているようです.

また、最近要望が増えてきたバックプレーンの光化をサポートするコネクタやハウジングも、各社よりリリースされています。大型の通信装置などであれば、このような「光バックプレーンハウジング」を使用することにより、通常の電気バックプレーンと同じように、カードをもったままそのまま挿抜するということもすでに実現可能です(図4).

国内では、主要ファイバ/コネクタベンダとして占河電工、 住友電工、フジクラなどが挙げられ、多チャネルに対応した

#### 〔図4〕バックプレーンの光化

- カード間接続をファイバに
- •バックプレーンはファイバシート • 光コネクタがインターフェースに なる
- •カードをもったまま挿抜可能なバ ックプレーンハウジングも各社よ り発売されている



ファイバやコネクタなどがすでに製品化されています. その他 のファイバベンダとしては、日本 MOLEX、住電オプコム、カ ルテック, 北日本電線, 日星電気, 日立電線, 三菱レイヨンな どがあります。

## **3** 日本における短距離光リンク市場

光技術の進歩も手伝って光が対象にする通信距離はどんどん 短くなってきており、同時にすでに紹介したように、高速電気信 号での限界も顕著になってきているという話をよく耳にします。

実際に、国内の電気メーカーを訪問した際、ノイズの影響な どを回避する方法として光を検討したいという話も少なくはあ りません 注1.

長距離伝送を行う通信装置だけではなく、ボード間、チップ 間にまで具体的に光を採用する動きが、通信装置以外のアプリ ケーションで加速しており、従来の電気配線から光配線への置 き換えが実際に進んできています.

WDM などの通信技術で大成功を収めた光技術が、より短い 距離で使用されるようになり、すでにコンピュータ、産業機器、 放送機器のマーケットにおいては光リンク方式が採用されてい ます。ただ、現在採用されている光モジュールは、ほとんどが 1チャネルのトランシーバで、SerDes に接続して高速シリアル 信号を複数本単位で伝送するには、このモジュールを複数個並 べなければならず、ボードスペース、消費電力、価格について の課題が依然として残ってしまいます.

つまり、1チャネルの光モジュールでは、電気による複数の 高速シリアル伝送を完全に補完するまでには至っていないのが 現状です.

## **4.** パラレル光モジュールとは

このような状況の中、数年前より注目されているのが VCSEL をベースとした多チャネルのパラレル光モジュールによるデー タ伝送です。複数の高速 I/O をそのまま光に変換するようなイ メージで、大量のデータを安定したアイパターンで伝送するこ とが可能になります.

装置間、ボード間のパラレル光伝送をキーテクノロジとして 位置付けた製品が、まさに各社で開発されはじめており、実際に 光配線が高速ボード設計者の選択肢の一つになりつつあります.

LAN などに用いられている伝送速度 1Gbps クラスの技術にお いては、1チャネルの光送受信モジュールと1本のファイバによ るシリアルデータ伝送が主流ですが、合計 10Gbps クラスの高 速データを接続するには、化合物半導体を使用した高速回路や 厳密な温度管理が必要となり、モジュールとしての巨大化、高 コスト化と多大な消費電力の増大をもたらしてしまいます.

目安としては、合計 5Gbps を超える装置間などの近距離伝送 (1km以内)を低コスト,低消費電力,省スペースで実現するに は、光によるパラレルデータ伝送を検討したほうが有利になる

注1:近年の伝送容量の膨大化にともない、装置内の伝送容量も増大の傾向にある。従来の電気信号にて大容量情報を伝送しようとした場合には、並列信号本数 を増やすこととなるが、これでは装置の小型化および低コスト化は実現できない。しかし、パラレル光モジュールを採用することで、並列信号本数は格段 に低減され、装置の小型化や低コスト化および長距離伝送が実現可能となる[日立ハイブリッドネットワーク(株)システム部 主任技師 川嶋氏のコメント]、

場合が多くなります(図5)。

多チャネルの高速シリアル信号伝送をノイズフリーで実現する"解決策"として、現在注目されているのが「パラレル光モジュール」です。

# 5。パラレル光モジュールの歴史

パラレル光モジュールの開発は、1990年代前半からLEDなどを光源として研究が始まりましたが、現在各社より製品化されているほとんどすべてのパラレル光モジュールは、VCSELを使用しています。このVCSELこそが、多チャネルの光電変換を圧倒的な小パッケージと低消費電力で実現することを可能にしています。

最初に12チャネルのパラレル光モジュールを製品化したのは Infineon Technologies 社で、1998年に発表されました。その後もアレイ状の多チャネル VCSEL が安定して供給できることを 背景に、2003年4月現在、15社以上のベンダがパラレル光モジュールを供給しており、1パッケージあたり最大で48チャネルまでサポートする製品も発表されています。

コモディティとなった VCSEL の発展とともにパラレル光モジュールも発展し、現在の伝送レートは1 チャネルあたり 1Gbps  $\sim 3.4$ Gbps 程度までをサポートしている製品がリリースされています.

# **6.** 国内市場における パラレル光モジュールへの要求

1チャネルの光モジュールにおける接続から、多チャネルのパラレル光モジュールによる光リンク接続へ、市場は確実に推移しています。"複数本の高速電気信号を任意のプロトコルでそのまま長距離転送してしまう"という発想、つまりバックプレーンの光化です。筆者は、パラレル光モジュールを多数の国内メーカーに紹介してきましたが、ターゲットとなるアプリケーションは、当初想像した以上に多岐にわたるものでした。具体的には産業機器では、

- IC テスタ、LCD テスタ、イメージテスタなど各種テスト 装置
- ハイエンド計測器
- ●地上波ディジタル放送システム機器/高速画像処理装置
- 業務用ハイエンドプリンタ、ハイエンド印刷機 ネットワーク/コンピュータ機器では、
- ●ハイエンドスイッチ/ルータ
- ディジタルクロスコネクト
- ADM (Add Drop Mux)
- ●携帯電話基地局/無線機
- RNC (Radio Network Controller)
- スーパーコンピュータ
- Sonet/SDH VSR リンク

#### 〔図5〕光モジュールの寸法比較

10Gビットシリアル光モジュール(Xenpak, Xpak, XFP) とCorona社40Gビット光モジュールの対比図



• 高速 SAN(Storage Area Netrwork) リンク, Fibre Channel 接続

などに使われています。

高速ボード設計者と話をしてみると、パラレル光モジュール に対する要求は、ほぼ次の数点に絞ることができました。

• 小型であること

もともと電気の置き換えをターゲットとした光モジュールは、 とにかく小型であることが要求されます。現在、ICで実現でき ているボード上に光モジュールが新たに加わることにより、 ボードスペースがなくなってしまっては、まったく意味がなく なってしまうからです。これは、光モジュールに接続されるコネクタをどれだけ小さいコネクタで実現するかということと同 じで、コネクタが巨大になってしまうとそれだけスペースを 取ってしまうことになり、設計が難しくなってしまいます。

• 消費電力が低いこと

携帯電話など、モバイルタイプの製品のみでなく、最近のアプリケーションではネットワーク基幹系の装置においても、消費電力に対する要求はますます強くなってきています。サーバなどに使用される CPU に関しても(もちろん機種にもよるが)低消費電力タイプが好まれ、消費電力は「低ければ低いほどよい」という声が大半を占めます。今後もこの動きは加速されていくものと思われます。バラレル/シリアル光モジュール問わず、「低消費電力」の光モジュールが今後もシェアを伸ばしていくのではないかと考えています。

• 低コストであること

コストに対する要求は、ますます厳しくなってきています。どの分野においてもこの傾向は顕著になっているのですが、VCSELベースのパラレル光モジュールは合計の伝送レートを考えた場合、1Gbps あたりの価格をシリアル光モジュールと比較して圧倒的に安くすることが可能です。端面発行レーザを内蔵した高価な光モジュールを使用するのではなく、電気高速I/Oの延長としてパラレル光モジュールを使用するためには、今後もますます価格が下がっていく必要があります。

## 特集 高速バスシステムの徹底研究

●(光モジュールの紹介とあわせて)光ファイバ、コネクタに関してアドバイスできること

先ほどもふれましたが、パラレル光モジュールがターゲットにしているアプリケーションは多岐にわたり、光モジュールや光ファイバを使用したことがないユーザーも少なくありません。とくに、装置内のバックプレーンを光化するとなると、バックプレーンに接続されるコネクタの形状や、電気バックプレーンの時と同様にボードを持ったまま挿抜できるようなアーキテクチャがすでに確立されているのかどうかという質問まで、いわゆる"光のハード"部分に関しての知識が必須となってきます。

どのファイバ/コネクタベンダがどのような製品を市場に投入しているか?というような情報も、初めて光モジュールを採用しようと考えているエンジニアには非常に重要な情報で、サポートが必要になってくる分野で、このあたりのハード面での制約によって、システムの構成が変わることもあります。

• ボード上の光モジュールの位置に制約がないこと

この点も意外に思われるかもしれませんが、今後ますます重要になってくるのではないかと思われます。現在でもほとんどの光モジュールは、ボードの端にしか置けないような設計になっています。現在発表されているほとんどのパラレル光モジュールは、バックエンドに SerDes と呼ばれる高速 I/O を内蔵した IC の使用を想定しています。SerDes と光モジュールの距離を離してしまうと、1 チャネルあたり 1Gbps 以上の電気信号をFR4 の基板上において数本伝送する場合、距離が長ければ長いほどノイズや減衰の影響が深刻になり、ボードの信頼性が低くなってしまうのです(図 6)。このため、光モジュールの位置にあわせて SerDes などの IC を移動させるのは、その分ボード設計の柔軟性が失われてしまうことにつながります。

また、現在のパラレル光モジュールは一定のエアフローを要求しているのに対し、実際のボード設計では場所によっては風があたりにくい部分が生まれ、それが問題になる場合もあります。光モジュールをボード上のどの部分にでも配置でき、エア

#### 〔図6〕実装位置の制限



フローに合わせてヒートシンクのカスタマイズが可能であれば、 そのような悩みをすべて解消することが可能になります.

## 7. 世界最小光モジュール" OptoCube40 "

このような市場の要求に対し、合計 40Gbps (最大) の光電変換を 1 チップあたり 1W (Typ.) の消費電力と 13mm 角のパッケージサイズで実現することを可能にしたパラレル光モジュールが、"OptoCube4o"(Corona Optical Systems 社、以下 Corona 社) です。 1cm² あたりに換算すると約 23Gbps の光電変換を行うことができる計算になります。 写真 1に、OptoCube4o の外観を示します。

Corona 社は 2000 年 2 月に設立され、本社を米国イリノイ州に置くパラレル光モジュール専業メーカーです。OptoCube40は12 チャネルのパラレル光モジュールで、2001 年よりリリースされています。チャネルあたりの転送レートは100Mbps~3.35 Gbpsをサポートし、12 チャネル合計で40Gbpsの光電変換を行うことが可能な光モジュールです。また、業界初の表面実装可能な光モジュールとして13mm角の世界最小パッケージで製品化しています。OptoCube40の仕様を表1に示します。

製造工程の自動化を実現した MCM (Multi chip module) タイプのモジュールで、リフローを通すことが可能なことから、通常の半導体部品と同等に取り扱うことも可能です。

光電変換のスピードは、光モジュールに送る LVDS または CML の電気信号のスピードによるため、たとえば XAUI 3.125Gbps の信号であれば、そのままのスピードで光に変換し、プロトコルもそのまま転送します。そのまま 12 チャネルを束ねれば合計約 38Gbps になります。100Mbps から 3.35Gbps であればどのようなスピード、プロトコルでも光にデータを変換し、ノイズの影響を受けることなく安定したアイパターンで最大600m まで高速データを送ることが可能となります。図7に3.35Gbps で通信中のアイパターンを示します。

なお、この光モジュールと Stratix を接続し、PCI ボード上に搭載した評価ボードを開発中です (コラム参照).

〔写真 1〕OptoCube40 の外観



#### 〔表 1〕OptoCube40の仕様

| TX          | 電気→光                       |
|-------------|----------------------------|
| RX          | 光→電気                       |
| ビットレート/チャネル | 100Mbps ~ 3.35Gbps         |
| チャネル数       | 12 チャネル                    |
| 電源電圧        | 3.3V (± 5 %)               |
| インターフェース    | CML/LVDS                   |
| BER         | < 10-12 (@223-1 PRBS)      |
| サイズ         | W13 × D13 × H4.8           |
| 944         | W13 × D13 × H9.8(ヒートシンク含む) |
| 消費電力        | 1W (Typ.)                  |
| レーザー波長      | 850nm (VCSEL)              |

# 8. VCSEL ベース光モジュールの将来動向

VCSELベースの光モジュールがねらっている市場はショートリーチの市場のみではありません。1 チャネルあたり 10Gをサポートする VCSELが製品化されれば、 $10G \times n$  チャネルをサポートとするパラレルモジュールも製品化され、ますます市場を広げていくものと思われます。

Corona 社では 2004 年中に  $13mm \times 13mm$  のパッケージで  $10Gbps \times 4$  チャネルを実現する製品をリリースする予定になっています.

短距離の10GビットEthernet 接続などは、850nmのVCSELを使用したパラレル光モジュールがどんどん進出してくるのではないでしょうか。また、波長帯域1310nmや1550nmのVCSELで数kmの光伝送を保証する製品も本格的に量産されれば、現在の端面発光レーザ(DFBレーザ/FPレーザ)の市場にVCSELベースの光モジュールが参入してくることになり、世界の大学や企業が、こぞって「本命」であるこの市場をねらっています。

将来的には、ボード上のチップ間インターフェースも光になる可能性があります。たとえば、ソニーが現在開発している次世代プロセッサには、将来的に光インターフェース回路の集積

〔図 7〕3.35Gbps 通信時のアイパターン



を検討しているようで、CPU同上を高速な光ネットワークでつなぐことを視野に入れているようです。

#### まとめ

1970年代より、長距離大容量データ伝送技術として発展してきた光伝送の技術は、いま新たな展開を迎えています。冒頭にも触れましたが、光伝送の技術がすでにネットワークの世界を飛び出し、ハードウェアの世界に進出してきました。

多チャネルの光モジュールという製品自体は、すでに安定した品質で量産化されており、この光伝送の技術をサポートし、光バックプレーンを実現するコネクタやファイバも各社より製品化されています。レーザ、ファイバ、パッケージング技術、新しい素材の導入など光技術を取り巻く環境はどんどん進歩し、改善されており、パラレル光モジュールが電気による多チャネル高速シリアル伝送を補完する技術として実際に採用され始めています。まずは装置間やボード間から、新しい技術の光が高速ボード設計者に着実に受け入れられています。

今後もノイズフリーで低消費電力を実現する技術としてパラレル光モジュールが認知され、電子回路設計者にとって光がより身近になるきっかけとなればと考えています.

こばやし・ゆうすけ (株)アルティマ

## Column

光モジュール搭載大規模 FPGA 評価 PCI ボード

OptoCube 光モジュールを搭載した、大規模 FPGA 評価用 PCI バスボードです (写真 A). アルテラ社製 FPGA Stratix (EP1S40 ~ EP1S80) を搭載し、光モジュール間は 840Mbps-12 チャネルで接続されています。その他、SXGA ビデオ D-A コンバータ、SO-DIMM や LVDS 通信ポートなどを搭載し、WDM やビデオ配信、RAID システムなどの設計に最適です。

#### ■問い合わせ先

(株)アルティマ プロダクトマーケティング部 TEL.045-476-2155

#### 〔写真 A〕光モジュール搭載大規模 FPGA 評価 PCI ボード



# PC/AT互換機チップセットの データ転送

PC/AT 互換機は、CPU が 486 の頃は 33MHz、Pentium が登場して 66MHz、Pentium IIIでは 133MHz というように FSB (Front Side Bus) が高速化してきた。さらに最近では、クロックの立ち上がりと立ち下がりの両エッジを使った DDR 動作や、4 倍のQDR 動作によるデータ転送で、最新 Pentium4 の FSB は 800MHz にも達した。すでに第1章で解説したように、これらは電源電圧や信号振幅の低電圧化により実現できるようになった。また、16 ビットから 32 ビット、64 ビットへと広がってきたバス幅も、HubInterfaceや HyperTransport では逆にビット幅が狭くなっている。ここでは、PC/AT 互換機のチップセットのデータ転送について解説する。

PCの周辺回路を数個のパッケージにまとめあげた、いわゆるチップセットと呼ばれるLSIは、CPUとともにマザーボードという車の両輪のような存在であるといってよいでしょう。

とくに Pentium 登場以降は、CPU の性能や機能を引き出すためにはチップセットも「セット」で考える必要があると考えられるようになり、PC向け CPU 供給の最大手である Intel自身がチップセットを積極的に開発、外販するようになりました。現在もなお、チップセットは CPU の性能向上にあわせて要求される性能を引き出せるようにしながら、PC アーキテクチャとの互換性と、新しい周辺機器への対応を図るという、難しい課題を解決しながら発展してきています。

ここでは、PCの歴史とともに歩んできたチップセットの性能向上のカギになったともいえる、チップセット相互の接続部分に注目してみることにしましょう。

#### ● 元祖 PC/AT

まず、元祖 PC といえる IBM の PC/AT についておさらいし

#### 〔図1〕PC/ATのブロック図



ておきましょう。PC/AT は、汎用のIC やごく小さなプログラマブルロジックの組み合わせで作られていました。PC/AT のブロック図の概略は、**図1**のようになっています。ISA バスは、PC/AT の前身である PC/XT の8 ビット幅のバスを拡張した、上位互換の 16 ビットバスです。ビデオカードや FDD/HDD のインターフェースカードなどが ISA バスで接続されます。

桑野雅彦

マザーボードの上に標準で搭載される割り込みコントローラ、DMA コントローラなどは、ISA バスからさらにバッファされたバス(Xバスと呼ぶこともある)の上に接続されています.

また、この当時は ISA バスと CPU バスの速度が同じだったこともあり、メモリの増設も ISA バスに増設メモリボードを入れて行うという方法がとられていました。 ISA バスのバスクロックは当初 6MHz でしたが、後に CPU の速度向上にあわせて 8MHz に引き上げられました。 16 ビット幅で最短 2 サイクルで終わるので、ISA バスのバンド幅は  $8 \times 2$  (バイト) ÷ 2 (サイクル) = 8M バイト/秒となります。

#### • 80386 時代

PC/AT は、回路図や BIOS のソースコードなどが公開されていたことから、これをデッドコピーした、いわゆる PC クローン機が多数発売されました。そのような中で、Compaq が 32 ビット CPU である 80386 を利用し、本家 PC/AT を超える性能の互換機を発売するにいたります。

とくに、80386から次の80486への切り替わりの頃には、さまざまなメーカーからチップセットがリリースされる状態になり、まさしく百花繚乱という様相を呈してきます.

この頃のシステム構成は、おおむね図2のようになっていました。ピン数の問題から、チップセット部分が分かれているものもありましたが、おおむね図のような構成です。PC/ATのマザーボードに載っていたロジックの大部分がチップセットに吸収されています。CPUが80386になり、データバス幅も32ビット、CPUクロックも16MHz以上となり、ISAバスではバンド幅が足りず性能が出ないため、メインメモリ(DRAM)は

ISA バスから切り離され、CPU バス側のチップセットが制御する形になりました。

シリアルポートやパラレルポート, FDDや HDD インターフェースなどは、PC/ATでは拡張ボードで提供されていましたが、パソコンとしてはほぼ必須になっていたことから、これらをまとめあげて ISA バスに直結するだけでよい SuperI/O と呼ばれるチップが登場し、マザーボードは大幅に簡素化されました。図では、キーボードコントローラやリアルタイムクロック(カレンダ時計)は別チップになっていますが、これらを内蔵した SuperI/O もありました。

ISA バスの性能が CPU の性能に対して低すぎることもあって、IBM は PC/AT の後継であった PS/2 で MCA (Micro Channel Architecture) という 32 ビットバスを搭載しますが、仕様を公開しないクローズドなものであったことから、Compaq などの 互換機メーカーが ISA の上位 互換バスとして EISA バスを提唱して対抗していました。しかし、結局どちらも消えていくことになりました

#### • 80486 時代

80386の上位互換である80486はパイプライン方式を取り入れ、浮動小数点コプロセッサや、キャッシュメモリなどを内蔵したものでした。ブロック図は図3のようなものです。DRAMの速度がCPUのバス速度に追従できなくなってきたことから、外部に二次キャッシュを用意するのが普通でした。DRAMとキャッシュメモリの制御もチップセットで行います。

この頃になると、PCのアプリケーションもテキストベースからグラフィカルなものが増えてきて、ビデオカードのグラフィック性能などが問われることが多くなってきます。このため、おもにディスプレイカードをターゲットとした高速ローカルバスとして、VL-BUS(VESA-Local Bus: VESAは Video Electronics Standard Associationの略)が設けられました。VL-BUSは、80486の外部バスをベースに考えられた32ビットバスです。最大66MHzで動作し、266Mバイト/秒という速度を実現していました。16ビットモードがあったり、最大10個のデバイスまで接続可能であるなどという特徴がありましたが、アドレスとデータをマルチプレクスしない32ビットバスであることから、信号線の本数も非常に多いうえ、80486という CPUのバス仕様に依存したものであったこと、Intelがオンボードのチップ間接続のためのバスとしてPCIバスを提唱し、普及につとめたことなどがあいまって、80486時代の終焉とともに消えていきました。

この頃までは、I/O もその多くは ISA バス接続で間に合わせている例がよく見られました。

# • 430HX (Pentium 時代)

80486の次に登場した Pentium の時代になると、CPUの性能向上とともに、外部バスの高速化への要求は一段と厳しくなり、Windows の普及とともにグラフィックだけでなく、HDD アクセスも高速化が必要となってきます。Intel は PCI バスの本格的な普及に本腰を上げてきます。

#### 「図 2〕80386 時代の代表的な PC/AT 互換機のブロック図



#### 〔図3〕80486 時代の代表的な PC/AT 互換機のブロック図



Intelは、当初はあまりチップセットの開発に熱心ではなく、 Zymos 社などから OEM 供給してもらうなどといった状態でしたが、PCへの新しい技術導入と性能向上にはチップセットの 改良も不可欠と考えたためか、開発に本腰を入れはじめます.

Pentium 時代の代表的なチップセットである 430HX を使ったシステムのブロック図が**図4**のようなものです。33MHz 動作で最大 133M バイト/秒の伝送速度があり、プラグアンドプレイにも対応した PCI バスがメインのシステムバスとして一般的なものとなりました。

430HX チップセットでは、図のように CPUバスと PCIバス の間に TXC, PCIバスと ISA バスの間に PIIX3 がバスブリッジとして配置されます。地図で上が北になることになぞらえて、TXC をノースブリッジ、PIIX3 のほうをサウスブリッジという

〔図 4〕 430HX チップセットの システム構成



### 〔図 5〕440BX チップセットの システム構成



#### 〔図6〕810チップセットのシステム構成



呼び方をすることが一般的なならわしとなっています.

信号レベルは、すべて 3.3V 系の TTL となっています。

TXC は CPU バスと PCI バスのブリッジのほか、DRAM とキャッシュメモリ制御を行うシステムコントローラとなっており、PIIX3のほうは PCI/ISA のブリッジに加えて IDE や USB といった負荷の高い I/O 関係の制御を担当します。ビデオカードや SCSI アダプタ、ネットワークカードなど、データ転送速度を要求するものなども PCI バス上に置くことが一般的となり、拡張バスの主役となりました。

# • 440BX(Pentium II 時代)

Pentium II 時代の代表的なチップセット 440BX を使ったシステムのブロック図は、図5のようなものです.ノースブリッジが 82443BX、サウスブリッジが 82371EB (PIIX4E) という組み合わせです.Pentium II では、二次キャッシュまで内部に取り込まれたので外部キャッシュがなくなりましたが、基本的な機能分担や、相互に PCI バスで接続されるところなどは 430HX と同じです.目新しいところとしては、AGP バスが設けられていることがあげられます.

Pentium 時代の後期から Pentium II の時代になると、PCでの 3D表示や、動画再生などもあたりまえのように行われるようになり、それとともにディスプレイカード用のデータトラフィックも格段に増加していきました。PCI バス接続では、貴重な共通バスのバンド幅の多くをグラフィックカードに食われてしまうことから、グラフィック関係専用のバスとして PCI バスとは独立した AGP バスが追加されたというわけです。

〔図7〕ハブインターフェースの信号



AGP バスは、32 ビット幅の PCI バスを 66MHz 動作にしたようなもので、最大転送速度は 266M バイト/秒でしたが、440BX に搭載された AGPX2 バスは、66MHz の基準クロックと STB/ STB# の位相をずらしたストローブ信号を使ってクロックの両エッジアクセスにすることで 2 倍の 533M バイト/秒のバスバンド幅を確保しています。

また、Pentium II からはホストバスが TTL ではなく電圧レベル 1.5V の AGTL+ に、さらに Pentium IIIは 1.25V の AGTL となっています。 AGP や SDRAM は 3.3V のままです。

#### • 810 (Celeron/Socket370 時代)

その後のPCの普及と高性能化は進み、ビデオだけでなく、ハードディスクなどのストレージ系デバイスも 440BX 時代のUDMA/33 (33M バイト/秒)から UDMA/66 (66M バイト/秒)と高速化さていきます。サウスブリッジが PCI バス接続ではディスクアクセスが PCI バスのバンド幅を食いつぶすということになってしまうことや、ISA バスの原則廃止など受けて、チップセットの構成が大幅に変更されることになりました。型番も新たに 800 番台シリーズが採用されます。

810 チップセットを使用した PC の構成は、**図 6** のようになっています。ノースブリッジ、サウスブリッジと呼ばれていたチップセットは、それぞれメモリコントロールハブ (82810)、I/O コントロールハブ (82801A) という名前に変更され、ハブの間は専用のローカルバス (HubInterface) で接続されます。ハブインターフェース部分を HubLink や HubLink Architecture と呼ぶこともあります。

810 のハブインターフェースは,66MHz のクロックで動作する電圧レベル 1.8V の8 ビットバスです.二つのストローブ信号を使い,1 クロックあたり 4 バイトの転送を行います.最大転送速度は 266M バイト/秒と,PCI バスの 2 倍の性能をもっています.これによって,ディスクとメモリ間のデータ転送において PCI バスがボトルネックになったり,大量のデータ転送にともない PCI バスが占有されてしまうことを防いでいます.

ハブインターフェースの信号接続関係は、**図7**のようにきわめてシンプルなものです。3V66は 66MHzのクロック、HL [10:0]が 11本のコマンド/データラインです。

また、HL STBとHL STB#がそれぞれ位相のずれたストロ

ーブ信号です. 周期はクロック周波数と同一で、それぞれの立ち上がり/立ち下がりのエッジでデータ転送を行うことで、1クロックあたり4バイト分のデータ転送を実現しています.

#### • 845G (Pentium4 時代)

ハブインターフェースによるチップセット間接続という考え方は、その後も継承されていきます。Pentium4用のチップセットである 845G も同様に、メモリコントローラハブと I/O コントローラハブに分かれています。845G チップセットを使ったPC のブロックは図8 のようになっています。ハブ相互の間の接続もやはりハブインターフェースですが、電圧レベルが810 などのハインターフェース (HL1.0) の 1.8V から 1.5V に引き下げたモード (HL1.5) が用意されました。HL1.5 も伝送速度はHL1.0 と同じ 266M バイト/秒です。

### • E7500 (Xeon サーバ用)

一般の PC用とは別に、Xeon を使用したサーバマシンをターゲットにしたのが E7500 チップセットです。 E7500 のチップセット間接続例を**図9** に示します。サーバの場合、大量のインターフェースカードが使用されることもあり、複数の PCI バスを実装することができるようになっています。

MCHとI/O コントロールハブ (ICH3-S) だけを切り出してみると、この部分の構成は845Gと同じ、HI1.5 による接続になっ

ています。HI1.5 ではダウンストリーム (CPUから I/O コントロールハブへの方向)のアドレス空間は、PCI バス自身が32 ビット空間であることから32 ビット分ですが、逆のアップストリーム方向では64 ビットのアドレス空間をもっており、4G バイトを超えるメモリ空間への転送が可能となっています。

 $E_{7500}$  で特徴的なのは、MCH から PCI/PCI-X に直接ブリッジする P64H2 を最大  $_3$  個までつなげられるようにしている部分です。 P64H2 は  $_{33}$ MHz または  $_{66}$ MHz の PCI バスのほか、 $_{66}$ MHz、 $_{100}$ MHz、 $_{133}$ MHz の PCI-X とインターフェースするチップです。

PCI-X は、PCI と比べて飛躍的にデータ転送速度が上がっていることから、P64H2 用の HubLink 側も改良され、HL2.0 となっています。HL2.0 は 66MHz のクロックで動作する点は HL1.5 と同じですが、データ幅が 16 ビットになり、さらに 1 クロックで8 回の転送を行うことで、最大 1G バイト/秒の転送速度を実現しています。

HL2.0 の伝送信号は,

• HL[21:20]: ECC信号

● HL[18:0] :ハブ間接続信号

PSTRBF : 下位8ビット第一ストローブ信号PSTRBS : 下位8ビット第二ストローブ信号

### 〔図 8〕845G チップセットのシステム構成



● PUSTRBF:上位 8 ビット第一スト

ローブ信号

● PUSTRBS : 上位 8 ビット第二スト

ローブ信号

CLK66 : 66MHz 基準クロック となっています。

### ● E8870 チップセット

E8870 チップセットは、大規模サーバを意識したものです。図 10 のように、最大 4 個のプロセッサに一つの SNC (Scalable Node Controller) が接続され、SNC の下にはさらに二つの SP (Scalability Ports) が引き出されています。各 SP は最大 3.2G バイト/秒の伝送速度をもち、I/O ハブと接続されます。PCI バスや旧来の I/O 関係は、I/O ハブから引き出されます。

さらに、SNC から引き出される SP と I/O ハブの間にポートスイッチ (LAN のスイッチングハブのようなもの) を接続することで、CPU + SNC のペアを複数接続したシステムも構成可能となります。

#### V-LINK(VIA: KM266/KN400)

Intel 以外のチップセットメーカーの製品も同じような変遷を遂げています。PCI バス接続によるノースブリッジ/サウスブリッジという構成のあと、やはりハブインターフェースとよく似たチップセット間専用バスを設けるようになりました。VIA のKM266 チップセットを使用したシステムブロックを図11 に示します。Intel のハブインターフェースに相当する部分はV-LINKという名称のバスになっています。66MHzの8ビットバスで266Mバイト/秒を実現しているということで、Intel のハブインターフェースと同様に、1クロックで4バイト分の転送を行っていることが読み取れます。

上位の KN400 チップセットでは、V-LINK が 8X V-LINK と 名を変え転送速度も V-LINK の 2 倍の 533M バイト/秒に引き上げられています。

#### MuTIOL(SIS)

SIS のチップセットも、チップ間を専用バスで接続する方式をとっています。SIS の専用バスは MuTIOL という名称がつけられています。伝送速度は SIS の 645 チップセット (SIS645 と SIS961 の組み合わせ) に採用されたものは Intel の HL2.0 と同様にバスクロック 66MHz でデータ幅は 16 ビットあり、1 クロックで 4 回の転送を行うことで 533M バイト/秒、さらに新しい648 チップセットでは、これをさらに引き上げた MuTIOL1G となり、1G バイト/秒のバンド幅をもつバスになっています。

MuTIOL採用のチップセットの構成は、図12のようになります。ノースブリッジ側でメモリやビデオカード関係を、サウスブリッジ側でI/O関係の面倒を見るという考え方は他社のも

#### 〔図9〕E7500チップセットのシステム構成



# 〔図 10〕 E8870 チップセットのシステム構成



のと同じですが、内部の考え方が変わっています。SISのチップが特徴的なのは、MuTIOLで接続されたチップセット間で複数のトランザクションをキューイングし、処理を並列実行できるようなしかけを設けて、性能向上を図っている点です。これを Hyper Streaming と呼んでいます。

図13は、サウスブリッジ側の内部構成です。一つのMuTIOLポートに対するアップストリーム方向、ダウンストリーム方向のそれぞれについて複数の伝送チャネルをもっており、メッセージ(パケット)ベースでの伝送制御を行います。通常であれば、下位の低速デバイスへのアクセスを行うと、動作が完了するまでバスが占有されてしまいますが、これを下のようにリクエスト/レスポンスというパケットに分割して、リクエストパケットを発行後MuTIOLバスを開放し、相手からの応答

# 〔図 11〕KM266 チップセットのシステム構成



を待ってレスポンスパケットを受け取るという方法にすること で、バスの有効利用を図るというわけです。この方法をスプリ ットトランザクションと呼んでいます。

# HyperTransport

AMD が発表した HyperTransport I/O Link はチップセット 間にとどまらず、半導体チップ同士を1対1で接続するための 汎用高速 I/O バスとして提唱されたものです。 AMD は各社に 呼びかけ、HyperTransport テクノロジコンソーシアム(http: //www.hypertransport.org/)を結成しました。当初8社 の集まりであったコンソーシアムも、4月1日現在で49社が参 加するものになっています。

HyperTransport の大きな特徴は,

- (1) ポイントツーポイント接続であること
- (2) 最大 12.8G バイトのアドレス空間をもつ
- (3) データバス幅が 2/4/8/16/32 ビットから選択可能
- (4) 800Mbps (バス幅 2 ビット, 200MHz 動作) から最大 51.2Gbp (バス幅 32 ビット、800MHz 動作)まで用途に応じて選択 可能

となるでしょう。

HyperTransport は、データやコマンドなどをパケット単位 でやりとりする方式をとっており、信号線は図14のようなご くシンプルなものです.

CAD(Comamnd/Address/Data)には、コマンドやアクセスす るアドレス情報, データなどの情報が乗ります. HyperTransport では CAD 信号の本数 (ビット数) は、2 ビットから 32 ビットま での5種類が定義されており、要求される伝送速度やチップの ピン数など、用途や目的に応じて選ぶことができるようになっ ています。図でもわかるとおり、HyperTransport は単方向の 伝送線路を上りと下りそれぞれ独立でもたせることで、全二重

#### 〔図 12〕 MuTIOL チップセットのシステム構成



#### 〔図 13〕 Hyper Streaming の構成



での通信を行えるようにしています。

CTL(Control)は、現在 CAD上にあるのがコントロールパケ ットなのか、データパケットなのかを示す信号です。

CLK (Clock) は、CAD や CTL 信号のための同期クロック 信号です。CLKはCAD信号8本ごとに1本用意されます。つ まり、CADが32ビットならクロックは4本、CADが16ビッ トならクロックは2本になります。CTLはCAD[0], つまり CAD の最下位ビットと同じクロックが使われます.

このように8ビットごとにクロックを分割することで、基板 上での配線長さの違いなどによるスキューの問題を回避してい ます。クロック周波数は、現在 200MHz から 800MHz までの 5 種類が定義されています。

HyperTransport の CAD ビット数とクロック周波数による 伝送速度の一覧を表1に示します。

HyperTransport の信号はポイントツーポイントで接続され ることになっていますが、LSI デバイス内部で Hyper Transport 信号を中継して,次の HyperTransport デバイスとつなぐとい う方式で複数のデバイスをチェーン, あるいはツリー状に接続 することもできるようにしています. 図15は、この一例を示 したものです. 図15で、Pとあるのはプライマリインターフェ ースブロック、S はセカンダリインターフェースブロックを示 します。円筒形のものはトンネルと呼ばれるもので、Hyper Transport パケットを細工せずにそのままもう一方のポートに 流すものです。

HyperTransport は、このようにブリッジとトンネルを組み 合わせることで、自由度の高いチップ間接続を実現していると

# 〔図 14〕 HyperTransport による接続



いうわけです.

HyperTransport によって、チップ間接続方式の標準化が図 られることで、さまざまな機能ブロックをもった LSI を自由に 結線して利用できるようになることが期待されるといえるでし よう.

PCの CPU は、まだまだ高速化の一途をたどるでしょう。さ らに次世代になれば、チップセット間のデータ転送量も増大す るでしょう。ISA接続、PCI接続、そして専用接続バスへと進 んできたチップセット間接続も、これに呼応してさらなる高速 化が図られていくのでしょう。また複数の伝送チャネルの使い 分けがなされていくような方向に向かうのかもしれません.

くわの・まさひこ パステルマジック

## 〔図 15〕 HyperTransport によるチップセットの接続構成例



〔表 1〕 HyperTransport の伝送速度

|            |        |      |        |      |        | 単位: Gbps |  |  |  |
|------------|--------|------|--------|------|--------|----------|--|--|--|
|            |        |      | CADバス幅 |      |        |          |  |  |  |
|            |        | 2ビット | 4ビット   | 8ビット | 16 ビット | 32 ビット   |  |  |  |
| CLK<br>周波数 | 200MHz | 0.8  | 1.6    | 3.2  | 6.4    | 12.8     |  |  |  |
|            | 400MHz | 1.6  | 3.2    | 6.4  | 12.8   | 25.6     |  |  |  |
|            | 500MHz | 2.0  | 4.0    | 8.0  | 16.0   | 32.0     |  |  |  |
|            | 600MHz | 2.4  | 4.8    | 9.6  | 19.2   | 38.4     |  |  |  |
|            | 800MHz | 3.2  | 6.4    | 12.8 | 25.6   | 51.2     |  |  |  |



# PCI Express 規格の概要

里見尚志

PCI Express は PCI の後継規格として、PC/AT 互換機だけでなく、今後のコンピュータシステム全般で通用する標準拡張バスとして規格化されたバスである。低電圧差動信号伝送、ポイントツーポイントで送受信独立の通信チャネル、パケット化されたスプリットトランザクション、リンク構成の違いによる高いスケーラビリティなど、ISA や PCI とはかなり異なるバスとなる。 (編集部)

# はじめに

PCI Express は、今後 10 年以上を見越した、従来のPCI バスに 代わる I/O バス規格である。2002 年夏に最初の規格が策定され、 対応製品の開発もすでに始まっている。本稿では PCI Express について、その概要とアーキテクチャについて解説する。

PCI Express の規格については日々アップデートされており、最新の情報については後述する PCI-SIG や Intel の PCI Express 関連情報を参照していただきたい。また、本解説では現在ドラフトとしてレビューされている情報も含まれており、正式な規格では変更となる可能性があることを留意してほしい。

● PCI Express が登場した背景

現在および今後のコンピューティング/コミュニケーションプラットホームのインターコネクトで要求される性能は、次のような技術革新により、PCIなどの既存パラレルバスの能力を越えつつある。

- 3GHz を越えるような高速 CPU
- ・メモリの高速化
- ●高性能グラフィックスコントローラ
- ●Gigabit Ethernet や 10Gビット Ethernet といった高速ネットワーク
- ●高速なストレージ/通信インターフェース
- ●接続する周辺機器の高速化

これにより現在のPCIバスを大きく越えるバンド幅や柔軟性をもつインターコネクト(I/Oバス)が要求されている.

PCI Express はこのニーズに応えるための I/O バスとして登場し、次のような要求を満足するものとなっている。

(1) 幅広いマーケットセグメントと新たなアプリケーションの サポート

デスクトップ, モバイル, ワークステーション, サーバ, コミュニケーションプラットホームや組み込み機器といったものをサポートする単一の I/O アーキテクチャ.

- (2) 低コストで大量のソリューションの提供 システムレベルで現在の PCI と同等かそれ以下のコスト.
- (3) 多様なプラットホームインターコネクト形態 チップ間接続、コネクタやケーブルによるボード間接続など.
- (4) 新たな機構的フォームファクタ モバイル, PCI と同形状, モジュール, カートリッジ.
- (5) PCI 互換のソフトウェアモデル

PCIで使用されているコンフィグレーションメカニズムをそのまま使用、既存 OS やデバイスドライバを変更せずに使用できる。PCI Express で新たに追加された機能のコンフィグレーションは、既存のコンフィグレーションを模範とする。

(6) 高性能

オーバヘッドや遅延を抑えることにより、アプリケーションレベルでのデータバンド幅やリンク使用効率を増大させる。またピンあたりのバンド幅を大きくし、全体でのピン数を削減する。レーン数や伝送周波数によりスケーラブルな性能を実現。

(7) 進化した機能

異なるデータタイプや伝送順序ルールの包含,異なる QoS (Qualities of Service)の提供によるサービスの差別化、電源管理,既存 PCI およびサイドバンド信号を使用しない PCI Express 固有のホットプラグ/ホットスワップ,リンクレベルおよびエンドツーエンドでのデータ完全性,エラーハンドリングとロギング,半導体プロセス技術への非依存性(送信側/受信側で異なる DC コモンモード電圧),テストの容易性(電気的適合性試験を試験装置との簡単な接続で実施可能)など.

### ● PCI Express の歴史

PCI Express は当初 3GIO や Serial PCI と呼ばれていた「第 3世代 I/O テクノロジ」<sup>造1</sup>である。2001 年 3 月に Intel が 3GIO, 同年 7 月に PCI-SIG が Serial PCI と呼ばれる構想を発表し, 2001 年 8 月になって PCI-SIG, Intel とともに Compag (現

注1:第1世代はISA, 第2世代はPCI/PCI-Xを指す.

#### 〔図 1〕既存 PCI システムと PCI Express システムの例・



Hewlett-Packard), Dell, IBM, Microsoft が参加してコード名「Arapahoe」としてワーキンググループが発足,新たなシリアル I/O インターコネクトアーキテクチャの策定が開始された。規格の名称としては 3GIO と呼ばれていたが、2002 年 4月になって PCI Express という正式名称 きとなった。最初の規格となる Revision 1.0 のドラフト版リリース/ファイナルレビューとともに PCI-SIG に移管され、2002 年 7月 22 日に「PCI Express Base Specification Revision 1.0」,「PCI Express Card Electromechanical Specification Revision 1.0」がリリースされた。

# **1.** PCI Express の概要

従来の PCI システムおよび PCI Express システムの例を**図 1**, 実際に想定される PCI Express プラットホーム例を**図 2**に示す. 従来の PCI, PCI-X, AGP, Hub Linkといったバスが PCI Express で置き換わり, 既存の PCI/PCI-X デバイスを接続するためにブリッジが使用される. チップセット間の接続も PCI Express となり, IEEE1394, Serial ATA, USB2.0 などは I/O ハブにより PCI Express に接続される. またサーバにおいては, InfiniBand HCA (Host Channel Adapter)を PCI Express に接続することも想定される.

PCI Express をバスとしてみた場合、次のような特徴がある.

- ポイントツーポイントのデュアルシンプレックス(送受信が 独立)通信チャネル
- 低電圧差動信号
- ●エンベデッドクロック(データにクロック信号を重畳)
- ●スケーラブルな周波数(第1世代で2.5Gbps)とバス幅(1, 2,

注2: PCI Express は PCI-SIG のトレードマークである.

### 〔図 2〕デスクトップ/モバイルでの PCI Express プラットホームの例



#### 4, 8, 12, 16, 32 レーン)

またプロトコルとしてみた場合は、以下のような特徴がある.

- 階層化構造
- PCI と同様のロード/ストアアーキテクチャ
- 完全にパケット化されたスプリットトランザクション
- PCI Express の構成要素

### ▶ポート (Port) /レーン (Lane) /リンク (Link) (図3)

ポートは物理的には同一半導体内にありリンクを形成するトランスミッタ/レシーバの集合で、論理的にはコンポーネント-リンク間のインターフェースを意味する.

レーンは差動信号ペアのセットで、送信側の信号ペア、受信 側の信号ペアからなる。

#### ▶ルートコンプレックス (Root Complex)

I/O 構造の最上位に位置し、CPU やメモリサブシステムを I/O に接続する。ブロック図などではメモリハブと記述されていることが多い。ルートコンプレックスは一つ以上の PCI Express ポート(ルートポート)をもち、それぞれのポートは独立した I/O 階層ドメインを形成する。I/O 階層ドメインは、単純なエンドポイントである場合や、多数のスイッチやエンドポイントから形成される場合がある。

#### ▶エンドポイント(End Point)

タイプoohのコンフィグレーション空間へッダをもつデバイス(具体的にはブリッジ以外のデバイス)で、レガシーエンドポイントと PCI Express エンドポイントに分けられる。両者の大きな違いは、PCI Express エンドポイントは BAR(ベースアドレスレジスタ)で I/O リソースを要求せず、このため I/O リクエストを生成しない。また PCI Express エンドポイントはロックリクエストもサポートしていない。

#### 〔図 **3**〕 ポート/レーン/リンクの関係



### 〔表 1〕代表的なリンク構成と伝送バンド幅

| リンク構成    | 信号レートバンド幅  | 実効伝送バンド幅(バイト/s) |      |  |
|----------|------------|-----------------|------|--|
| ソマン情以    | (片方向, bps) | 片方向             | 双方向  |  |
| ×1リンク    | 2.5G       | 250M            | 500M |  |
| ×4リンク    | 10G        | 1G              | 2G   |  |
| ×8リンク    | 20G        | 2G              | 4G   |  |
| × 16 リンク | 40G        | 4G              | 8G   |  |
| × 32 リンク | 8oG        | 8G              | 16G  |  |

注: データは 8B10B コーディングされるため、実効伝送バンド幅は信号 レートバンド幅の 80%となる

#### ▶スイッチ (Switch)

二つ以上のポートを結合し、ポート間でのパケットルーティングを行う。コンフィグレーションソフトウェアからは、スイッチは仮想 PCI-PCI ブリッジの集合体と認識される(図4).

#### ▶ PCI Express-PCI ブリッジ (PCI Express-PCI Bridge)

PCI Express から PCI/PCI-X への接続を提供する. これにより既存の PCI/PCI-X デバイスを PCI Express システム上で使用することができる.

#### 階層アーキテクチャ

従来のPCIのアーキテクチャは、プロトコルとシグナリングが密接に関連する構造だったが、PCI Express では一般的な通信プロトコルや InfiniBand のように、独立した階層構造となっている(図5). これにより各層のモジュール性が確保され、スケーラビリティをもたせることやモジュールの再利用が可能となる。たとえば、新たな信号コーディング方式や伝送媒体を採用する場合、物理層を変更するだけでデータリンク層やトランザクション層は変更せずに対応できる。

アーキテクチャの中心となるのはトランザクション層,データリンク層,物理層で、それぞれ次のような役割をもつ(図**6**).

#### ▶トランザクション層

トランザクション層は最上位に位置し、トランザクションレイヤパケット(TLP)の組み立て、分解機能をもつ。TLPはリードやライト、各種イベントといったトランザクションの伝達に用いられる。またトランザクション層はTLPのためのクレジットを用いたフロー制御を行う。各層におけるTLPの概要を図7に示す。

### 〔図4〕スイッチの論理的構造



注3: 一般的な読み方は「バイN」、数字の読み方は、筆者の場合 N=8 までは英語読み、12 以上は日本語読みである。

#### 〔図 5〕 PCI と PCI Express のアーキテクチャ





#### 〔図 6〕 PCI Express の階層構造



#### 〔図7〕トランザクション層パケット(TLP)フォーマット-



ECRC:エンドツーエンドCRC LCRC:リンクCRC

#### ▶データリンク層

データリンク層のおもな役割は、エラー検出/訂正(再送)により TLP のデータ完全性を保証することと、リンク管理である。データリンク層間ではリンク管理やフロー制御のためのパケットをやりとりする。このパケットは TLP と区別するために、データリンクレイヤパケット(DLLP)と呼ばれる。

# ▶物理層

物理層はドライバ,入力バッファ,SerDes <sup>注 4</sup>,PLL やインピーダンス整合回路といったインターフェース動作のために必要な回路を含んでいる。また論理的な機能としてインターフェースの初期化・保守の機能をもつ。物理層はデータリンク層/トランザクション層を実際のリンクで使用される信号技術から独立させる役目ももっている。

各層についての詳細は後述する.

# コンフィグレーション空間

PCI Express は従来の PCI と同様にコンフィグレーション空間をもつが、その大きさは従来の PCI が 256 バイトであるのに対し、4096 バイトへと拡張されている(**図8**). これにより、多数のデバイス固有レジスタセットを必要とするデバイス(ホストブリッジなど)に対しても、将来的に十分な空間が確保され

### 〔図 8〕 PCI Express のコンフィグレーション空間



ている.

PCI Express では、コンフィグレーション空間へのアクセスはフラットなメモリ空間へのアクセス(コンフィグレーションリード/ライト)で行われ、バス/デバイス/機能/レジスタ番号はメモリアドレスにマップされている。

空間の先頭 256 バイトは PCI コンフィグレーション空間として, BIOS や従来の OS から I/O ポート CF8/CFC を使用した方

注4: Serializer/Deserializer の略で、パラレル-シリアル/シリアル-パラレル変換器のこと.

# 〔図 9〕 PCI Express アドインカードの形状



〔図 10〕 PCI Express のコネクタ形状



[写真 1] PCI Express のコネクタ(上: × 16, 下: × 1)



法でもアクセスできる. 従来のアクセスを PCI Express でのア クセスに変換する機能はホストブリッジ上に実装される。ooh から 3Fh までは PCI 2.3 互換のコングレーションヘッダとなっ ている。これにより、PCI Express で拡張された機能以外であ れば従来の OS やソフトウェアをそのまま使用することができ る. PCI Express で拡張された機能を使用するためには、OS や ソフトウェアの修正や新規開発が必要となる.

# $oldsymbol{2}_ullet$ PCI Express のフォームファクタ

PCI Express ではさまざまなフォームファクタ (形状) が考え られているが、ここでは現在具体化しているものについて紹介 する.

# アドインカードとコネクタ

カードの形状としては従来の PCI と同じで、既存の ATX シャーシをそのまま使用することが可能である(図9). コネク タは PCI と同じようなもので、コストのかからないものとなっ ている. リンクとしては $\times$ 1,  $\times$ 4,  $\times$ 8,  $\times$ 16が規定されてお り、それぞれコネクタの大きさが異なる(図10、写真1). ×1 の場合は36ピン,×16の場合は164ピンとなっている。コネ クタへはリンク幅が同じか狭いカードを装着することができる (表 2).

電源としては+3.3V, +12V, +3.3Vaux(オプション)の3種類が供給される(表3). PCIと比較すると消費電力の大きな アドインカードのために+12Vの容量が強化され、+5Vと -12Vが取り除かれている。グラフィックスカード向け×16 コネクタでは、当初 40W であった最大消費電力が、近い将来

〔表 2〕カードとスロットの互換性

| スロット | × 1 | × 4 | × 8 | × 16 |
|------|-----|-----|-----|------|
| × 1  | 必須  | 必須  | 必須  | 必須   |
| × 4  | 不可能 | 必須  | 可能  | 可能   |
| × 8  | 不可能 | 不可能 | 必須  | 可能   |
| × 16 | 不可能 | 不可能 | 不可能 | 必須   |

広いリンク幅のカードを狭いリンク幅のコネクタに装着するこ とは物理的に不可能となっている

〔表3〕コネクタから供給される電源と最大消費電力

| コネクタ種別と<br>最大消費電力 | × 1(デスクトップ)<br>10W |         | ×16(グラフィックス)<br>75W(パワーアップ時<br>は25W) |
|-------------------|--------------------|---------|--------------------------------------|
| $+3.3V \pm 9\%$   | 最大3A               | 最大3A    | 最大3A                                 |
| $+12V \pm 8\%$    | 最大 0.5A            | 最大 2.1A | 最大5.5A                               |
| +3.3Vaux ± 9%     | 最大375mA            | 最大375mA | 最大375mA                              |

グラフィックス用×16コネクタの最大消費電力は当初40Wだったものが、現在は 75Wとなっている

|       |     |         | _  |     |      |    |    |       |  |
|-------|-----|---------|----|-----|------|----|----|-------|--|
| 〔表 4〕 | PCI | Express | コネ | ・クタ | 【(スロ | 1ツ | 上) | のピン配置 |  |

| ピン | サイドB    | サイドA     | ピン | サイドB    | サイドA  | ピン | サイドB    | サイドA   | ピン | サイドB      | サイドA   |
|----|---------|----------|----|---------|-------|----|---------|--------|----|-----------|--------|
| 番号 | 名 称     | 名 称      | 番号 | 名 称     | 名 称   | 番号 | 名 称     | 名 称    | 番号 | 名 称       | 名 称    |
| 1  | + 12V   | PRSNT1#  | 21 | GND     | PERp1 | 42 | PETn6   | GND    | 63 | PETn11    | GND    |
| 2  | + 12V   | + 12V    | 22 | GND     | PERn1 | 43 | GND     | PERp6  | 64 | GND       | PERp11 |
| 3  | + 12V   | + 12V    | 23 | РЕТр2   | GND   | 44 | GND     | PERn6  | 65 | GND       | PERn11 |
| 4  | GND     | GND      | 24 | PETn2   | GND   | 45 | PETp7   | GND    | 66 | PETp12    | GND    |
| 5  | SMCLK   | TCK      | 25 | GND     | PERp2 | 46 | PETn7   | GND    | 67 | PETn12    | GND    |
| 6  | SMDAT   | TDI      | 26 | GND     | PERn2 | 47 | GND     | PERp7  | 68 | GND       | PERp12 |
| 7  | GND     | TDO      | 27 | РЕТр3   | GND   | 48 | PRSNT2# | PERn7  | 69 | GND       | PERn12 |
| 8  | + 3.3V  | TMS      | 28 | PETn3   | GND   | 49 | GND     | GND    | 70 | PETp13    | GND    |
| 9  | TRST#   | + 3.3V   | 29 | GND     | PERp3 |    | ×8の場合は  | ここまで   | 71 | PETn13    | GND    |
| 10 | 3.3Vaux | + 3.3V   | 30 | RSVD    | PERn3 | 50 | PETp8   | RSVD   | 72 | GND       | PERp13 |
| 11 | WAKE#   | PERST#   | 31 | PRSNT2# | GND   | 51 | PETn8   | GND    | 73 | GND       | PERn13 |
|    | キー      |          | 32 | GND     | RSVD  | 52 | GND     | PERp8  | 74 | PETp14    | GND    |
| 12 | RSVD    | GND      |    | ×4の場合は  | ここまで  | 53 | GND     | PERn8  | 75 | PETn14    | GND    |
| 13 | GND     | REFCLK + | 33 | PETp4   | RSVD  | 54 | РЕТр9   | GND    | 76 | GND       | PERp14 |
| 14 | РЕТро   | REFCLK - | 34 | PETn4   | GND   | 55 | PETn9   | GND    | 77 | GND       | PERn14 |
| 15 | PETno   | GND      | 35 | GND     | PERp4 | 56 | GND     | PERp9  | 78 | PETp15    | GND    |
| 16 | GND     | PERpo    | 36 | GND     | PERn4 | 57 | GND     | PERn9  | 79 | PETn15    | GND    |
| 17 | PRSNT2# | PERno    | 37 | PETp5   | GND   | 58 | PETp10  | GND    | 80 | GND       | PERp15 |
| 18 | GND     | GND      | 38 | PETn5   | GND   | 59 | PETn10  | GND    | 81 | PRSNT2#   | PERn15 |
|    | ×1の場合は  | ここまで     | 39 | GND     | PERp5 | 60 | GND     | PERp10 | 82 | RSVD      | GND    |
| 19 | PETp1   | RSVD     | 40 | GND     | PERn5 | 61 | GND     | PERn10 |    | × 16 の場合は | ここまで   |
| 20 | PETn1   | GND      | 41 | PETp6   | GND   | 62 | PETp11  | GND    |    |           |        |

予想される消費電力増加にともない、75W に変更されている. PCI Express のリンクや電源以外には、リファレンスクロック、カード検出信号、リセット、Wake、オプションで JTAG と SM バスといった信号が接続される.表4にピン配置を示す. 最初に実現される PCI Express 対応マザーボードの形態としては、グラフィックス用に×16、汎用 I/O 用に×1 コネクタを 搭載、これに従来の PCI コネクタを複数搭載したものになると

### ● プラグインカード(NEWCARD)

思われる<sup>注 5</sup>.

現在 NEWCARD<sup>±6</sup>と呼ばれていて、PC カードを置き換えるものである。大きさはシングルで PC カードの半分程度、ダブルはシングルを横に 2 枚並べた大きさとなる (図 11). 二つのスロットが横方向に並ぶこととなり、NEWCARD2 枚のスロットで現在の PC カード 1 枚のスロットとほぼ同じ大きさとなる。これにより、薄型化するモバイルプラットホームに対応することができる。スロットからはイジェクト機構が省略され、コネクタも簡単な構造になるなど、低コストを意識したものとなっている。

コネクタは片側に 28 のコンタクトが 1mm ピッチで並んだ形となっていて、抜き差しの回数としては 5000 回から 1 万回の耐久性をもつ。NEWCARD スロットにはインターフェースとして PCI Express  $(×1 \lor 2)$ , USB 2.0 が直接出ており、NEWCARD は PCI Express を使用したカード、USB 2.0 を使用したカードとなる (図 12).

NEWCARD の規格は現在ドラフトレビューされており、2003

[図 11] NEWCARD の外観例(シングル幅)



年末までには PCMCIA からリリースされる予定である.

#### Mini PCI Express

現在の Mini PCI を置き換えるもので、エンドユーザーによる着脱ではなく、BTO/CTO(Build To Order/Configure To Order)で製造時に装着するといった状況を想定している。カードの大きさは Mini PCI Type IIIカードの半分となっていて、Mini PCI と同じスペースで 52 ピンのモジュールを二つ装着することが可能となっている (**図 13**).

インターフェースとしては、NEWCARDと同じように PCI Express (×1リンク)と USB2.0 が直接出ている。これにより Mini PCI Express と NEWCARD 間で共通の技術が使用でき、相互の移行が容易となる。

注5: ISA/PCIの共存したマザーボードのようなものを想像してほしい. 注6: 現在は NEWCARD と呼ばれているが、名称が変更となる可能性がある。

#### 「図 12 NEWCARD スロットの構成例



注:図では省略されているが、SM バスも各スロットに接続されている

#### (図 13) Mini PCI Express カード



ては $\times$ 1から $\times$ 16までのリンクの使用が想定されている。カートリッジのような形<sup>注7</sup>で扱いやすく、シャーシを開閉することなくホットリムーブ/ホットプラグを行うことができる。

# **3.** PCI Express のアーキテクチャ

PCI Express アーキテクチャの中心となっているトランザクション層、データリンク層、物理層について、それぞれポイントとなる点を解説する。

▶ トランザクション層

トランザクション層のおもな役割は、上位のソフトウェア層と下位のデータリンク層の間でトランザクションレイヤパケット(TLP)の組み立てと分解を行うことである。

# ▶アドレス空間とトランザクションタイプ

PCI Express では四つのアドレス空間が定義されている. 従来の PCI でサポートされていたメモリ, I/O, コンフィグレー

Mini PCI Express の規格は現在レビジョン 1.0 のドラフトレビューが PCI-SIG メンバにより実施されている.

サーバ I/O モジュール (SIOM)

サーバやワークステーションでの使用を想定したもので、現在 PCI-SIG で検討が進んでいる。ホストインターフェースとし

注7: InfiniBand のモジュールに非常によく似ている.

# Column 1

PCI Express と InfiniBand

筆者は以前、2001年11月号の本誌でInfiniBandについて紹介した。当時PCI Express はまだ3GIOと呼ばれており、その概要しかわかっていなかった。InfiniBandの規格を見て感じたことは、上位層であるトランスポート層や通信/ネットワーク管理といったものが細かに規定されており、「重いプロトコル」だな、ということであった(ちなみにInfiniBandのアーキテクチャ仕様書は約2000ページある)。InfiniBandはストレージ向けで3GIOとは直接バッティングしないが、InfiniBandのサブセットであれば競合すると思っていた。ふたを開けてみると、PCI Express はInfiniBandの

ぜい肉をそぎ落として、既存のPCIとの互換性を最大限考慮したものとなっていた。物理層やデータリンク層については、InfiniBandとほとんど同じものとなっている。

InfiniBand はその後 Intel が対応半導体の開発を中止, Microsoft も Windows .NET Server (Windows Server 2003) での対応を中止するなど、以前のような勢いがなくなってきた。これは InfiniBand がまったく新しい、革命的 (revolutionary) アプローチであったのに加え、その仕様も複雑で開発にも工数がかかったのに対し、各メーカーは既存の技術を生かした進化的 (Evolutionary) アプローチに注力したためだと考えられる.

現在 InfiniBand は仕様の 1.1 がリリースされ、対応製品も一部メーカーから出荷されている。また InfiniBand をベースとした独自 I/O をもった製品を開発販売しているメーカーもある。

4

ション空間に加えて、メッセージ空間が追加された $^{\pm 8}$ . それぞれの空間に対してトランザクションタイプが定義されている (表5). メモリトランザクションでは 32 ビットアドレスと 64 ビットアドレスが使用できる。I/O トランザクションは I/O 空間を使用するレガシーデバイスの互換性のためにサポートされており、将来的には必要性がなくなってくる (PCI Express では I/O 空間の使用は推奨されていない). メッセージトランザクションは単にメッセージとも呼ばれ、PCI Express デバイス間のインバンドでのイベント通知やメッセージ交換に使用される。割り込み要求や確認はメッセージを「仮想ワイヤ」として使用することにより伝達される。

#### ▶トランザクションレイヤパケット(TLP)

TLPのフォーマットを**図7**(p.83)に示す。ヘッダ長は 3DW(DWはダブルワードの略で、合計 12 バイト)または 4DW(16 バイト)で、TLPのフォーマット(ヘッダ長とペイロードの有無)、トランザクションタイプ、トラフィッククラス(TC)、アトリビュートやペイロード長などの情報が含まれる。パケット内の最大ペイロード長は 1024DW(4096 バイト)である。

ECRC はエンドツーエンドのデータ完全性を保証するためのもので、TLP 部分の32 ビット CRC である。これはスイッチ内部などで TLP にエラーが発生した場合、LCRC(リンク CRC)ではエラーを検出できないためである(エラーとなった TLPでLCRC が再計算されるため)。

リクエストは完了パケットが不要なもの(Posted)と必要なもの(Non-posted)がある。Non-posted リクエストは、リクエストと完了が 1対1で連続しなくてもよいスプリットトランザクション方式で、トランザクション ID によりリクエストと完了

〔表5〕アドレス空間とトランザクションタイプ

| アドレス空間   | トランザク<br>ションタイプ  | Posted/<br>Non-posted | 用途                     |  |  |
|----------|------------------|-----------------------|------------------------|--|--|
| メモリ      | Read             | NP                    | メモリ空間とのデータ転送           |  |  |
| <i>y</i> | Write            | P                     | アピノエ同じのア ア報及           |  |  |
| I/O      | Read             | NP                    | I/O空間とのデータ転送           |  |  |
| 1/0      | Write            | NP                    | 1/0 主向とジノ ノ 転送         |  |  |
| コンフィグ    | Read             | NP                    | デバイスのコンフィグレー           |  |  |
| レーション    | Write            | NP                    | ションとセットアップ             |  |  |
| メッセージ    | 基本(ベンダ<br>定義を含む) | P                     | イベント通知や一般的な<br>メッセージ送信 |  |  |

Non-posted (NP) の場合は完了パケットの返送が必要, Posted の場合は不要

が関連づけられる.

#### ▶トラフィッククラスと仮想チャネル

上位のソフトウェアはトラフィッククラス (TC: Traffic Class)を使用することによりトラフィックの差別化を行うことができる。たとえば、映像データをネットワークのデータよりも優先して転送するといったことが可能となる。TCはTCoからTC7までの八つがある。

仮想チャネル(VC: Virtual Channel) はそれぞれ独立した仮想通信パスで、それぞれがリソース(バッファやキュー)をもち、独立したフロー制御を行う(**図 14**). VCo は必須で、コストパフォーマンスのトレードオフに応じてその他の仮想チャネル( $VC1 \sim VC7$ )が実装される。

トランザクション層内では TCが VC にマッピングされる. 一つの VC に対して一つ, または複数の TC をマッピングできる(VC の数が少ない場合). 単純な例では,各 TC から各 VC

# 〔図 14〕仮想チャネルの概念



注8:メッセージ空間というよりも、メッセージというトランザクションタイプが追加されたというほうが自然である。

に 1 対 1, すべての TC を VC0 にマッピングといったことが考えられる。 TC0-VC0 のマッピングは必須/固定で、それ以外のマッピングは上位のソフトウェアから制御される。

#### ▶フロー制御

受信バッファのオーバフローを避け、伝送の順序を確立するためにフロー制御(FC: Flow Control)が行われる。フロー制御はリンク間のポイントツーポイントで行われ、エンドツーエンドではない。したがって、フロー制御により最終的な相手(コンプリータ)にバケットが届いたことを確認することはできない。

PCI Express では「クレジット」によるフロー制御を行う、受信側はリンク初期化時にバッファ容量(クレジット値)を送信側に通知し、送信側はクレジット値と送信するパケットの長さを比較して一定の残りがある場合のみパケットを送信する<sup>注9</sup>。クレジットには六つの種類があり、それぞれで「残高管理」が行われる(表**6**)。

フロー制御の情報交換はデータリンク層の DLLP を使用して 行われる. フロー制御は TLP にのみ適用され, DLLP には適用 されない (DLLP は常時送受信可能).

#### データリンク層

データリンク層のおもな役割は、リンク上の二つのコンポーネント間で信頼性の高い TLP 交換機能を提供することである。

#### ▶ TLP の扱い

トランザクション層から受け取った TLP に対しては、先頭に 2バイト(使用しているのは 12 ビット)のシーケンス番号、末尾に 4バイトのリンク CRC(LCRC)を付加して、物理層に渡される(**図7**、p.83). TLP はリトライバッファに保管され、相手から受信確認 (ACK) が届くまで再送される。TLP の送信に失

# 〔表 6〕フロー制御のクレジットタイプ

| クレジットタイプ | 適用される TLP の情報             |
|----------|---------------------------|
| PH       | Posted リクエスト ヘッダ          |
| PD       | Posted リクエスト データペイロード     |
| NPH      | Non-posted リクエスト ヘッダ      |
| NPD      | Non-posted リクエスト データペイロード |
| CPLH     | コンプリーション ヘッダ              |
| CPLD     | コンプリーション データペイロード         |

#### 〔図 15〕データリンク層パケット(DLLP)のフォーマット



注9: PCI Express ワークグループのチェアマン Ajay Bhatt氏は、クレ ジットカードの利用限度額にたとえていた。

注 10: LFSR で使用される多項式が規格の 1.0a で変更された.

敗が続いた場合は、リンク異常であると判断して物理層に対してリンクの再トレーニングを要求する。リンクのトレーニングが失敗した場合、データリンクの状態はインアクティブに遷移する.

物理層から受け取った TLP はシーケンス番号と LCRC が検査され、正常であればトランザクション層に渡される。エラーがあった場合は再送を要求する.

#### ▶データリンクレイヤパケット(DLLP)

データリンク層が生成するパケットは DLLP と呼ばれ、データリンク層間でやりとりされる。 DLLP には次のような種類がある.

#### Ack/Nak

TLPの受信確認, リトライ(再送)

- InitFC1/InitFC2/UpdateFC フロー制御の初期化とアップデート
- ●電源管理のための DLLP

DLLP の長さは6バイトで,種類を示す DLLP タイプ(1バイト),DLLP の種類で固有の情報(3バイト),CRC(2バイト)から構成される(**図 15**).

### ● 物理層-論理サブブロック

物理層の論理サブブロックでのおもな役割は、データリンク層から受け取ったパケットを電気サブブロックで送信できる形式に変換することである。また物理層を制御/管理する機能ももっている。

# ▶データ符号化とパラレル-シリアル変換

PCI Express はデータ符号化に 8B/10B 変換を用いる (**コラム 2** を参照). 変換されたデータはシリアル変換され, LSB からレーン上に送信される. レーンが複数ある場合は, 符号化の前にデータがバイト単位で各レーンに割り振られる (**図 16**).

#### ▶特殊符号(Kコード)

8B/10B符号では通常のデータを表現する符号のほかに、Kコード (Kキャラクタ)と呼ばれる特殊符号があり、TLP/DLLPのフレーミングやリンク管理に使用される。TLPと DLLP は容易に識別できるように、異なる開始フレーミング符号が付加される (TLP は STP/K27.7,DLLP は SDP/K28.2)。

#### ▶データスクランブリング

特殊符号以外のデータについては、リニアフィードバックシフトレジスタ (LFSR) 注10 を用いてデータのスクランブリングを行っている。これにより同一や規則的なデータが連続した場合もスクランブル後のデータはほぼランダムとなり、信号のスペクトルが広がることにより EMI を低減することができる。送信側でのスクランブリングは 8B/10B 符号化の前に行われ、受信側でのデスクランブリングは 8B/10B 復号化の後で行われる。

### ▶リンク初期化とトレーニング

リンクは通常に使用される前に、初期化とトレーニングが行われる。トレーニングでは次のようなことが実施される。

データレートのネゴシエーション

# Column 2

8B/10B 符号化

8B/10B符号化は PCI Express のみでなく 100Base-X やシリアル ATA でも使用されている符号化方式である。1983 年に IBM が開発したもので、論文「A DC-Balanced、 Partitioned-Block、8B/10B Transmission Code」の PDF ファイルを IBM Journal の Webサイト (http://www.research.ibm.com/journal/)から入手可能である。

• 符号化の特徴

8B/10B 符号化は、8 ビットのデータを 10 ビットの符号に変換する方法で、次のような特徴をもっている。

- (1) 0や1が連続するデータでも符号化後はビット変化(信号のエッジ)が多くなり、データからのクロック抽出が可能となる(たとえば ooh は 0110001011 に変換される(図 A)
- (2) 0 の数と 1 の数が同じになるため、DC バランスがとれ、AC カップリングが可能
- (3) 符号空間が広がるため、データ以外に制御のための特殊符号を入れることができる
- (4) 減衰の大きな 1/5 以下 (<250MHz) の周波数成分を減少させることができる
- (5) ディスパリティにより符号のエラー検出が可能
- (6) 実効データ転送レートは8ビット/10ビットで80%になって しまう
- 符号化の方法

8 ビットデータの各ビットは、LSB から MSB にむかって A、B、C、D、E、F、G、H と呼ばれ、ABCDE(5 ビット)と FGH(3 ビット)の二つのグループに分けられる.符号化された 10 ビットは a、b、c、d、e、i、f、g、h、j(アルファベット順でないことに注意)と呼ばれ、abcdei(6 ビット)と fghj(4 ビット)の二つのグループに分けられる.

入力の種類(データ/特殊符号), ランニングディスパリティ(後述)の値をパラメータとして, ABCDE が abcdei に, FGH が fghi に変換される. 変換後の最大ランレングス (0/1 の最大連続数) は 5, 0と1の比率は 5:5, 6:4, 4:6 のいずれかとなる.

キャラクタコード

ooh から FFh までのデータは Dm.n という名称で呼ばれる. m, n はそれぞれ ABCDE, FGH の値(10 進)の値である. たとえば B4h は 10110100b なので D20.5 となる. データは D コードまたは D キャラクタと呼ばれる.

256 種類のデータ以外に 12 種類の特殊符号が Kコード (K キャラクタ) として定義されている ( $\mathbf{表}$  **A**). K コードは各種リンク管理や TLP/DLLP のフレームキャラクタとして用いられる.

#### 〔図 A〕データ 00h の符号化例

# オーダセット

通常のデータではない制御情報で、Kコード単独またはKコードとDコードの組み合わせが用いられる. PCI Express ではリンクの初期化、トレーニングなどに用いられる.

• ディスパリティ

ディスパリティとは、符号化されたデータ(シンボル)の1の 数と0の数の違いである。ディスパリティには次の二つの状態が ある

●ニュートラル:0と1の数が同じ(5個)

●ポジティブ :1の数が0の数より多い(6個と4個)

●ネガティブ :0の数が1の数より多い(6個と4個)

ランニングディスパリティ(RD)とは、送信されるシンボルの ディスパリティを積算したもので、同様にニュートラル/ポジティ ブ/ネガティブ状態のいずれかをとる。

8B/10B符号化では、DCバランスを保つために0と1の出現回数を同じにする必要があるため、以下のルールが適用される.

- ●現在のRDがネガティブの場合は、次のシンボルのディスバリティはニュートラルかポジティブでなければならない
- ●現在のRDがポジティブの場合は、次のシンボルのディスパリティはニュートラルかネガティブでなければならない

D/K コードでは、それぞれのコードに対して現在の RD がネガティブの場合 (Current RD -) とポジティブの場合 (Current RD +) のシンボルがある。たとえば Do.o (ooh) の場合は Current RD - が 1001110100, RD + が 0110001011, D12.3 (6Ch) の場合は RD - が 00110111100, RD + が 0011010011 である。

受信側では現在の RD から次に受信するシンボルのディスパリティ (Current RD -/RD +)を予測でき、伝送路上でのエラーを検出可能である (受信したものが予測と異なる場合).

#### 〔表 A〕 12 種類の K コード (PCI Express での定義)

|       |      |                           | -                                |
|-------|------|---------------------------|----------------------------------|
| コード   | シンボル | 名 称                       | 用途                               |
| K28.5 | COM  | Comma                     | リンク初期化と管理に使用                     |
| K27.7 | STP  | Start TLP                 | TLP 開始                           |
| K28.2 | SDP  | Start DLLP                | DLLP 開始                          |
| K29.7 | END  | End                       | TLP/DLLP終了                       |
| K30.7 | EDB  | EnD Bad                   | Nullified TLP終了                  |
| K23.7 | PAD  | Pad                       | フレーミングとリンク幅/<br>レーン順序の調停に使用      |
| K28.0 | SKP  | Skip                      | ポート間のビットレート差<br>補償に使用            |
| K28.1 | FTS  | Fast Training<br>Sequence | Los から Lo へ遷移するため<br>のオーダセット内で使用 |
| K28.3 | IDL  | Idle                      | 電気的アイドルオーダセット<br>内で使用            |
| K28.4 |      |                           | (予約済み)                           |
| K28.6 |      |                           | (予約済み)                           |
| K28.7 |      |                           | (予約済み)                           |

#### 〔図 16〕×4リンクでのバイトストライピング例



- ●ビット/符号同期
- ●レーン極性の反転(受信側で極性を検出し、必要であれば反 転する)
- ●リンク内でのレーン順序の決定
- ●リンク幅(×1~×32)のネゴシエーション
- レーン間のスキュー調整

トレーニングはトレーニングシーケンスオーダセット (TS1/TS2)と呼ばれる 16 シンボルのデータを繰り返し送受信 することにより行われる.

Los というリンクの低消費電力ステートから通常ステート (Lo) に復帰する際には、ファーストトレーニングシーケンス (FTS) という短時間で完了するトレーニングが用いられる.

### 〔表 7〕リンクステート

| ステート | 状 態                                 | Lo復帰にかかる時間 |
|------|-------------------------------------|------------|
| Lo   | アクティブ(通常)                           |            |
| Los  | リンクはコモンモード電圧<br>クロックや主電源はオン         | 16ns ∼ 4μs |
| L1   | リンクはコモンモード電圧<br>クロックはオフ, 主電源はオン     | 1~数 10μs   |
| L2   | クロック,主電源ともにオフ<br>補助電源(Vaux)がある場合は供給 | システムに依存    |

L2 からの復帰時間は、電源や PLL の立ち上がり時間などに依存する

#### ▶電源管理とリンクステート

リンクの消費電力を低く抑えるために、Lo/Los/L1/L2というリンクステートが定義されている(表7). Loが通常のモードで、LosからL2へと低消費電力になるが、Loへの復帰にも時間がかかるようになる。ソフトウェアによる電源管理に加えて、アクティブステート電源管理を積極的に行うことにより、消費電力を極力小さくすることが可能である(図17).

#### 物理層-電気サブブロック

物理層の電気サブブロックでのおもな役割は、論理サブブロックでシリアル化されたデータをレーン上に送信することと、レーン上のデータを受信して論理サブブロックに渡すことである(図18)、おもな送信出力/受信入力の規格を表8に示す。

# ▶基準クロックとスペクトラム拡散クロック (SSC: Spread Spectrum Clock)

リンク上のそれぞれのポートは互いに 600ppm 以内のデータレートで送信を行わなければならない。 言い換えると、ビットレートのクロックソースは ± 300ppm の許容差に収まらなければいけない.

PCI Express では EMI を低減するためにデータレートを通常値から+0%~-0.5%の範囲で変調することができる.変調レートは 30kHz から 33kHz の範囲に収まらなければいけない.この場合もポート間で 600ppm の許容差を満たす必要があるため,SSC を使用する場合は一般的にリンク上の両方のポートは同一クロックソースで動作させる必要がある.

# ▶ AC カップリング

リンクの送信側では AC カップリング用のコンデンサが実装される。これにより、送信側と受信側の DC コモンモード電圧が同一である必要はなくなる。このため送信側と受信側で異なる設計、半導体プロセス、電源電圧を使用することが可能となる。現在の PCI のように、5V と 3.3V での相互互換性といったことを考える必要がなくなる。

### ▶ DCコモンモード電圧

受信側の DC コモンモード電圧は AC カップリングされているため常に oV である.

#### 〔図17〕アクティブステート電源管理



#### 〔図18〕物理層の回路例



〔表 8〕 トランスミッタ出力/レシーバ入力の 代表的な規格

| パラメータ           | 最 小    | 標準    | 最大     | 単位 |                |
|-----------------|--------|-------|--------|----|----------------|
| UI(ユニットインターバル)  | 399.88 | 400   | 400.12 | ps | 400ps ± 300ppm |
| 差動出力電圧          | 0.800  |       | 1.2    | V  |                |
| 差動入力電圧          | 0.175  |       | 1.200  | V  |                |
| デエンファシス出力       | - 3.0  | - 3.5 | - 4.0  | dB |                |
| 送信最小アイ幅         | 0.70   |       |        | UI |                |
| 受信最小アイ幅         | 0.4    |       |        | UI |                |
| 最大送信ジッタ         |        |       | 0.15   | UI | ジッタ中心からの振れ     |
| 最大受信ジッタ         |        |       | 0.3    | UI | ジッタ中心からの振れ     |
| 送信立ち上がり/立ち下がり時間 | 0.125  |       |        | UI | 時間換算で 50ps     |
| 差動インピーダンス       | 80     | 100   | 120    | Ω  |                |
| ACカップリングコンデンサ   | 75     |       | 200    | nF | トランスミッタ側       |

# 〔図19〕デエンファシスによる送信波形と受信波形



送信側の DC コモンモード電圧は差動ペア間の平均電圧とな る. たとえば、差動ペアが 0.1V から 0.4V で振れている場合は、 DC コモンモード電圧は 0.25V となる.

#### ▶電気的アイドル状態

電気的アイドル状態とは、トランスミッタの差動信号ペアの 電圧が同一で一定である定常状態のことである。電気的アイド ル状態は、おもに節電やインアクティブ状態で使用される.

#### ▶損失(差動電圧振幅の減少)

システム内での損失は、システムが適切に機能するためにコ

ントロールする必要がある重要なパラメータである、最悪の場 合での損失はトランスミッタの最小送信差動電圧 800mV と最 小受信差動電圧 175mV より、13.2dB となる、送信側の差動電 圧を大きくすることにより、損失に対して余裕を持たせること ができる. 4層 FR-4 基板の場合に想定されるコネクタ含めたレ ーンの最大レース長は20インチ程度である.

#### ▶デエンファシス

同一極性のビットが連続する場合は、二つ目のビットからは 差動電圧レベルを 3.5 ± 0.5dB 落とす必要がある。これをデエ

### 〔写真 2〕オシロスコープによる PCI Express 物理層評価



Intel Developer Forum Japan での展示、コネクタを経由した受信側のアイバターン測定、信号速度は規格を超える3.25Gbps

ンファシスという(**図19**). 伝送路の周波数依存性減衰のため、変化するビットの場合は高周波成分が多く、減衰により受信側の波形が小さくなるが、変化しないビットの場合は高周波成分が少なく、相対的に受信側の波形が大きくなる. このため、受信側での波形を一定とするためにデエンファシスを行う.

# **4.** PCI Express 規格化の現状

Base Specification は、第2版となる Revision 1.0a が 2003 年 4月 15日にリリースされた。軽微な修正や定義の明確化に加えて、プロトコルなどに関する変更も加わっている。また Card Electromechanical Specification も第2版である Revision 1.0a も同時にリリースされている。

次の規格については、現在 SIG メンバによるレビューが実施されている.

- PCI Express to PCI/PCI-X Bridge Specification Revision
   1.0
- Mini PCI Express Card Electromechanical Specification Revision 1.0

また、次のような規格が順次リリースされる予定である.

- PCI Express Server Module Electromechanical Specification
- ●PCI Express Client Module Specification(PCMCIAから 2003 年秋にリリース予定)
- PCI Express Advanced TCA Specification (PICMIG)
- PCI Express Advanced Packet Switching Specification (Arapahoe Work Group)

PCI Express の規格書については、PCI-SIG メンバ企業に所属していれば Web より無償でダウンロード可能である。メンバ以外の場合は、PCI-SIG より有償でハードコピーを入手できる。PCI-SIG 以外の規格書については、それぞれの Web を参照されたい。

# ● PCI Express 対応製品の開発

国内外の企業により PCI Express 対応の半導体,ボード,コネクタなどの開発が進んでおり,2003 年末には最初の対応製品がリリースされると考えられる。またプロトコルアナライザや高性能オシロスコープ/プローブに代表される各種 PCI Express 対応測定機器は、すでにリリースされているか、または現在開発が進んでいる。

2003年4月に開催された Intel Developer Forum Japan では、グラフィックス用に×16、汎用 I/O 用に×1の PCI Express を搭載し実際に動作するマザーボードや、各種測定機器が展示されていた(写真2).

# • PCI Express に関する情報について

メンバ企業に所属していれば、PCI-SIGのWeb(http://www.pcisig.org/)から規格書やプレゼンテーション資料を 無償でダウンロードすることが可能である.

Intel Developer Network for PCI Express では、ユーザー登録(無償)することにより各種ドキュメントをダウンロード、PCI Express 関連の情報を電子メールで受け取ることができる (http://developer.intel.com/technology/pciexpress/index.htm).

PCI Express 関連の書籍としては、Intel Press より「Introduction to PCI Express:A Hardware and Software Developer's Guide」が出版されている。

また、PC 関連のトレーニング/書籍を提供している MINDSHARE (http://www.mindshare.com/) は PCI Express のトレーニングコースをオンサイト/インターネット上 で提供しており、PCI Express を解説した書籍を 2003 年 11 月 に出版する予定である.

# おわりに

PCI Express では、すでに 5Gbps や 10Gbps といった速度もロードマップ上では見えてきており、今後 10年を越えるレンジで標準 I/O インターコネクトとなることは確実と考えられる。また PCI との互換性により、従来の ISA から PCI よりも早いスピードで移行が進むであろう。

ただし、信号の速度が従来のPCI/PCI-Xよりも格段に速くなっているため、技術的にクリアすべきハードルが多数ある. とくに、電気的部分でのシグナルインテグリティは非常に重要なポイントといえる.

PCI Express という言葉は一般的になってきたが、現時点で入手できる情報は非常に少ない。本解説が、PCI Express に対する理解への第一歩になれば幸いである。

#### さとみ・たかし

アジレント・テクノロジー(株) 電子計測本部 ロジック・高速デジタル アプリケーション・スペシャリスト

# PCI-Xの特徴とプロトコル

村井康秀

前章の PCI Express は、現在規格が決まったところで、実際の対応製品はこれから登場するという新しい規格である。ここで紹介する PCI-X は、サーバ用途向けのマザーボードではすでに採用され、 PCI-X 対応の Gigabit Ethernet カードや UltraSCSI カードなど、より高速な転送を要求されるカードも市販されているなど、現時点ですぐに利用できる高速バスである。 (編集部)

# はじめに

現在もパソコンでは標準拡張バスとして利用されている PCIですが、サーバにおいては、転送スピードを上げた PCI の上位互換規格である PCI-X が利用されるようになってきました。このPCI-X は、1999年に PCI-SIG (Peripheral Component Interconnect Special Interest Group) によって策定され、PCI バスのアーキテクチャはそのままに、技術要望を満たした仕様としてデビューしています。さらに、PCI-X 2.0 のリリースで高速モードのモード 2 という、より高速な転送が可能になりました。

ここでは、PCI-Xの概略の特徴や新しく追加されたプロトコル、またPCI-Xモード2の特徴、そして最後に実際のトレースデータを使ってPCI-Xのプロトコルについて解説します。

**1.** PCI-X の特徴

# ● PCIと PCI-X の性能比較

PCI バスの最高スペックである 66 MHz/64 ビット時のデータ 転送レートは 533 M バイト/秒ですが、PCI-X 1.0 ではこれを 133 MHz/64 ビットにすることで最大 1066 M バイト/秒としています。 さらに、PCI-X 2.0 では同じ 133 MHz/64 ビットで、データ転送レートを 2 倍 (DDR) または 4 倍 (QDR) にしています

〔表 1〕PCI と PCI-X の性能比較

| 規 格             | バス幅    | クロック周波数 | 最大データ転送      |
|-----------------|--------|---------|--------------|
| PCI 2.2         | 32 ビット | ззМНг   | 133M バイト/秒   |
| PCI 2.2         | 32 ビット | 66MHz   | 266M バイト/秒   |
| PCI 2.2         | 64 ビット | ззМНг   | 266M バイト/秒   |
| PCI 2.2         | 64 ビット | 66MHz   | 533M バイト/秒   |
| PCI-X 1.0       | 64 ビット | 66MHz   | 533M バイト/秒   |
| PCI-X 1.0       | 64 ビット | 133MHz  | 1,066M バイト/秒 |
| PCI-X 2.0 (DDR) | 64 ビット | 133MHz  | 2,133M バイト/秒 |
| PCI-X 2.0 (QDR) | 64 ビット | 133MHz  | 4,266M バイト/秒 |

(表 1). PCI-X 2.0 では、PCI-X 1.0 と 互換性のあるモードをモード 1、DDR や QDR 動作のモードをモード 2 としています。 PCI-X 2.0 のモード 2 は、DDR や QDR 動作でさらに信号レベルなども異なる (1.5V) ので、電気的にはまったく別のバスと考えることもできます。

#### ● PCI-X 対応カードとシステム

図1に PCI-X 対応カードの形状やロゴを示します。 PCI-X には 32 ビット幅という規格はないので、物理的なボード形状は 64 ビット PCI カードと同じです。また、電圧キーは 3.3V 版の位置になります。

また、PCI-X 対応システムでは、接続できるスロットの数も 増加しています。66MHzのPCIバスでは最大2スロットまで だったのが、66MHzのPCI-Xでは最大4スロットとなってい

### 〔図1〕PCI-X対応カード







(**b**) PCI-X 1.0 □ □





(c) PCI-X 2.0 □ □

#### 〔表 2〕PCI/PCI-Xシステムのスロット数

| 規格    | クロック周波数 | 最大スロット数 |
|-------|---------|---------|
| PCI   | 33MHz   | 4~6     |
| PCI   | 66MHz   | 2       |
| PCI-X | 66MHz   | 4       |
| PCI-X | 100MHz  | 2       |
| PCI-X | 133MHz  | 1       |

#### 〔表4〕システム初期化時の信号

|        | PCI       |           | PCI-X                 |                         |                          |  |  |
|--------|-----------|-----------|-----------------------|-------------------------|--------------------------|--|--|
|        | 32<br>ビット | 64<br>ビット | 66MHz<br>(50 ~ 66MHz) | 100MHz<br>(66 ~ 100MHz) | 133MHz<br>(100 ~ 133MHz) |  |  |
| TRDY#  | " H "     | " H "     | " L "                 | " H "                   | " L "                    |  |  |
| STOP#  | " H "     | " H "     | " H "                 | " L "                   | " L "                    |  |  |
| REQ64# | " H "     | " L "     | " L "                 | " L "                   | " L "                    |  |  |

#### ます(表2).

表2を見ると、クロック周波数が 100MHz という項目が見えます。これは、バスクロック 100MHz 動作の PCI-X 対応ボードという仕様があるわけではありません (図1にも PCI-X100というロゴはない)。表2を見るとわかるように、133MHz 動作のPCI-X の場合、拡張スロットは一つしか実装できません。

66MHz より高速な性能が欲しいが、拡張性も考慮して2スロットは欲しいという要求に対応できるよう、バスクロックを100MHz にすることで最大2スロットまで使えるようにしたシステム側の仕様です。このスロットには133MHz 対応のボードを差し込むことで、バスクロックは100MHz で動作します。

### ● PCIと PCI-X の互換性

表3に PCI と PCI-X の互換性を示します。たとえば、既存の PCI システムに PCI-X のカードを挿した場合は、PCI-X のカードは PCI ボードとして利用できます。また、その逆に PCI-X システムに PCI カードを挿した場合は、その PCI-X スロット(およびそのバスに接続されている PCI-X スロットと PCI-X デバイス)は PCI モードとして動作します。

図2にカードの識別方法を示します。PCIXCAP信号は、サ

イドBの38番ピンです. 従来のPCIでは,グラウンドに接続されている端子です. バスクロック66MHz対応のPCI-Xではプルダウン,133MHz対応のPCI-Xでは開放状態のままにします. PCI-X対応のシステムではこのピンを操作し,接続されているカードがPCI-Xに対応しているかを判定します.

システム側はPCIXCAP信号でカードを識別できますが、カード側はどうでしょうか。表4にシステム初期化時の信号を示します。リセット信号が解除されたとき、つまりRST信号の立ち上がりエッジ時に、表4に示した各信号の状態を判定することで、カード側はどのモードで動作すればよいのかを判定します。

# $oldsymbol{2}_{ullet}$ PCI-X のプロトコル

リクエスタとコンプリータ

PCIでは、イニシエータ (マスタ)/ターゲットという呼び方をしていましたが、<math>PCI-X ではイニシエータをリクエスタ (Requester) とコンプリータ (Completer) と呼びます.

また,バスコマンドも一部変更になっています(表5). PCI-X

#### 〔表 3〕PCIとPCI-Xの互換性

PCI の 33MHz 対応は、PCI-X のシステムやアドインカード作成には必須事項である. 一方、66MHz はオプションであるため、設計者が状況に応じて対応させる. たとえば 100MHz 対応PCI-X システムに 66MHz PCI カードを搭載した場合,a) のように通常は 33MHz で動作する.PCI-X システムが 66MHz に対応するようになっていれば、b) のように 66MHz で動作させることが可能である (太枠内は PCI-X モード).

| ターゲット         |        | 現行の PCI カード       |                              |                              | PCI-X カード                    |                               |
|---------------|--------|-------------------|------------------------------|------------------------------|------------------------------|-------------------------------|
| ボード システムボード   |        | 33MHz<br>(5V I/O) | 33MHz<br>(3.3V I/O<br>または汎用) | 66MHz<br>(3.3V I/O<br>または汎用) | 66MHz<br>(3.3V I/O<br>または汎用) | 133MHz<br>(3.3V I/O<br>または汎用) |
| 従来の<br>システム   | 33MHz  | 33MHz<br>(5V I/O) | 33MHz<br>(5V I/O)            | 33MHz<br>(5V I/O)            | 33MHz<br>(5V I/O)            | 33MHz<br>(5V I/O)             |
|               | 66MHz  | 1                 | 33                           | 66                           | a) 33<br>b) 66               | a) 33<br>b) 66                |
| PCI-X<br>システム | 66MHz  |                   | 33                           | 33                           | 66                           | 66                            |
|               | 100MHz |                   | 33                           | a) 33<br>b) 66               | 66                           | 100                           |
|               | 133MHz | ı                 | 33                           | a) 33<br>b) 66               | 66                           | 133                           |

### 〔図2〕カードの識別方法



で変更になったバスコマンドについては後述します. なお, 表 **5**の中にある「Alias to Memory Read Block」と「Alias to Memory Write Block」は将来の拡張用で, 現在は使えません.

# • 追加された機能

PCI-X は PCI と比較して、次の六つの項目が追加/拡張されています。

- (1) アトリビュートフェーズ (Attribute Phase)
- (2) スプリットトランザクション (Split Transactions)
- (3) リラックスオーダリング (Relaxed Ordering)
- (4) ノンキャッシュコヒーレントトランザクション (Non-Cache-Coherent Transaction)
- (5) オプティマイズウェイトステート (Optimized Wait States)
- (6) スタンダードブロックサイズムーブメント (Standard Block Size Movement)

#### • アトリビュートフェーズ

PCIのターゲット側は、どのイニシエータからのアクセスなのか、バースト転送の場合は何ワードのアクセスをするつもりなのかを判定することはできませんでした。つまり、どこの誰に指示されたかはよくわからないが、とにかく指定されたアドレスが自分のアドレスであればアクセスを行い、FRAME#がディアサートされるのを今か今かと待ちながらバースト転送をしていました。

PCI-Xでは、どこ(バス番号)の誰(デバイス/ファンクション番号)が要求したアクセスなのか、またバースト転送の場合は何バイトのアクセスなのかを、トランザクション開始の時点で判定できるよう、バスアクセスの属性情報が追加されました。

図3に、PCIとPCI-Xのデータ転送のようすを示します。PCIと比較して大きく異なるのは、アドレスフェーズの次のクロックにアトリビュートフェーズが追加された点です。

**図4**にアトリビュートフェーズの内容を示します。トランザクションサイズやリクエスタのアイデンティティ、またキャッシュ検索要求やリラックスオーダリングの有無などの情報が格納されます。

# • スプリットトランザクション

実際のデータ転送効率を良くするためのプロトコルで、データ転送の一連のトランザクションを要求するフェーズと実際に転送されるフェーズを分割するものです。たとえば、リードサイクルにおいて、リクエスタの要求するデータをコンプリータがすぐに用意できない場合、コンプリータはスプリットレスポンスを返すことにより、一度トランザクションを終了します。これによりターゲット側の動作が遅れてもバスは開放されるので、イニシエータ側は転送されるデータを待つことなく、次々と新たな要求をターゲット側に送れます。

また、コンプリータがデータ転送の用意できた時点で、今度 はリクエスタとなり、要求元にライトサイクルで返すことによってトランザクションが終了します。

このプロトコルで、不必要なウェイトサイクルやリトライの

#### 〔表5〕PCI-Xのバスコマンド

| C/B # | 現状の PCI コマンド          | PCI-X コマンド                  |
|-------|-----------------------|-----------------------------|
| 0110  | Memory Read           | Memory Read DWORD           |
| 0111  | Memory Write          | Memory Write DWORD          |
| 1110  | Memory Read Line      | Memory Read Block           |
| 1111  | Memory Write and Inv. | Memory Write Block          |
| 1000  | Reserved              | Alias to Memory Read Block  |
| 1001  | Reserved              | Alias to Memory Write Block |
| 0010  | I/O Read              | I/O Read                    |
| 0011  | I/O Write             | I/O Write                   |
| 1010  | Config Read           | Config Read                 |
| 1011  | Config Write          | Config Write                |
| 1100  | Memory Read Multiple  | Split Completion            |
| 0000  | IntAck                | IntAck                      |
| 0001  | Special Cycle         | Special Cycle               |
| 1101  | Dual Address Cycle    | Dual Address Cycle          |
| 0100  | Reserved              | Reserved                    |
| 0101  | Reserved              | Reserved                    |
|       |                       |                             |

発生を防止し、実質転送レートを向上させることができます.

図5に、スプリットレスポンスのバスの動作を示します。スプリットレスポンスは DEVSEL# と STOP# を"H", TRDY# を"L"にして、トランザクションを終了します。

この後、データ転送の準備ができたコンプリータ側はバスの制御権を取得し、リクエスタから要求のあったデータをスプリットコンプレッションコマンドで返します。このときのアドレスフェーズのビット  $29 \sim 8$  には、スプリットレスポンスを返したときのリクエスタのアトリビュートフェーズの値を入れます。ビット  $31 \sim 30$  および 7 は予約されており、ビット  $6 \sim 0$  は Lower Address を入れます

### • リラックスオーダリング

PCIでは、PCI-PCIブリッジは要求を受け取った順番に処理を実行しますが、PCI-Xではこの順番を重要視せず、デバイスが対応できる順番に次々と処理を実行します。つまり、PCIでは複数のデバイスに要求した処理は、必ず要求した順番でしか処理が実行されないため、最初に要求した処理に時間がかかってしまうと、それ以降の処理はずっと待たされるわけです。

PCI-Xでは、後から要求された処理でも先に実行できるので、バスを効率よく使うことが可能です。PCI-X-PCI-Xブリッジがこのように順番を入れ替えることが可能なのは、アトリビュートフェーズにより、リクエスタの情報が伝わっているからです。リラックスオーダリングを許可する場合は、アトリビュートフェーズのビット29を1にします。

### • ノンキャッシュコヒーレントトランザクション

このトランザクションはマルチプロセッサシステムを使う際に、ホスト PCI-X ブリッジの負担を軽くしてより高速にデータ転送を実行するためのものです。通常のシングルプロセッサシステムでは、このトランザクションは使いません。

マルチプロセッサシステムにおける PCI では、メインメモリ

#### 「図3」PCIと PCI-X のデータ転送



IRDY# TRDY# DEVSEL#

(b) PCI-X(PCI-X1.0)

# 〔図4〕アトリビュートフェーズの内容

| 35 32                | 31 30 29 28 24 23 16 15 11 10 8 7                         | 0    |  |  |  |  |  |
|----------------------|-----------------------------------------------------------|------|--|--|--|--|--|
| 上位バイト<br>カウント        | $\begin{bmatrix} R & N & R & & & & & & & & & & & & & & &$ | カウント |  |  |  |  |  |
| C/BE[3~0]#           | AD[31:0]                                                  |      |  |  |  |  |  |
| ( <b>a</b> ) パースト転送時 |                                                           |      |  |  |  |  |  |
| 35 32                | 31 30 29 28 24 23 16 15 11 10 8 7                         | 0    |  |  |  |  |  |
| バイト<br>イネーブル         | R N S O タグ リクエスタバス番号 リクエスタ ファンクション 番号 リザー                 | ーブ   |  |  |  |  |  |
| C/BE[3~0]#           | AD[31:0]                                                  |      |  |  |  |  |  |
|                      |                                                           |      |  |  |  |  |  |

(b) シングルデータ転送時

R : Reserve NS: No Snoop RO: Relaxed Ordering に書き込まれた内容は常にブリッジからキャッシュにアップデートされており、この結果ブリッジがキャッシュにアップデートしている間は、他のトランザクションが起こせませんでした。

PCI-Xでは、このノンキャッシュコヒーレントトランザクションによって、ブリッジがそれぞれのプロセッサのキャッシュをアップデートする作業をキャンセルすることが可能になりました。ゆえに、ブリッジの負担が軽くなり、すぐに次のトランザクションを受け入れられます。

ノンキャッシュコヒーレントトランザクションを使う場合は、アトリビュートフェーズのビット  $30 \, {\rm c} \, \, 1$  にします.

#### • オプティマイズウェイトステート

PCI-Xでは、ウェイトをかけるタイミングにも制限が加えられました。ウェイトを入れられるのは、アトリビュートフェーズの直後から最初のデータ転送を開始するまでの間のみで、一度データ転送が始まると、ウェイトを入れることができません。これはバス転送効率、スループットを上げるためです。

すでに説明したように、PCIではターゲット側が何ワードのバースト転送なのかを判定することはできませんでした。そのため、ターゲット側がデータ転送の準備ができていない場合は、TRDY#をディアサートすることでバースト転送の途中でもイニシエータに対してウェイトを要求できました。

しかし、PCI-Xでは、アトリビュートフェーズにより事前に 転送バイト数を知ることができるので、あらかじめ内部のバッ ファにデータを用意しておくことで、バースト転送の途中で ウェイトを要求する必要はなくなりました。

#### • スタンダードブロックサイズムーブメント

もちろん、何らかの理由で、バースト転送途中でウェイトを入れたい場合もあるでしょう。そのような場合は、128バイト境界においてのみ、そのトランザクションをディスコネクトすることができるという規定もあります。

これらの点より、バースト転送対応のデバイスを設計する場合は、内部に最低限 128 バイト分のバッファは必要であることがわかります.

なお、ディスコネクトの実際の制御方法も、PCI-Xでは PCIと若干異なります。PCIでは、STOP#のアサート時に TRDY#をアサートするか(データ転送をともなうディスコネクト)、TRDY#はディアサートするか(データ転送をともなわないディスコネクト)などがありました。PCI-Xではオプティマイズウェイトステートにより、データ転送の途中で TRDY#をディアサートすることはできませんし、スタンダードブロックサイズムーブメントによりディスコネクトをかけるバイト境界も規定されています。

#### 〔図5〕スプリットレスポンスのバスの動作



したがって、実際の動作は図6のようになります。図中の転送データ a が 128 バイト境界の最後のデータ転送だとします。このアローワブルディスコネクトバウンダリ (ADB) の 4 クロック前までに、STOP# をアサートしておかなければなりません。リクエスタがそれを認識して FRAME# がディアサートされるのは ADB の 2 クロック前となります。

# 3. PCI-X 2.0 について

PCI-X 2.0 ではさらなる高速転送を実現するため、PCI や PCI-X 1.0 に対して仕様を変更しています。 PCI-X 2.0 では PCI-X 1.0 と E を と E と E を そ ー E ド E と E で E と E で E と E で E と E で E と E で E と E で E と E で E と E で E と E で E と E で E と E で E と E で E と E で E と E で E と E で E と E で E と E で E と E で E と E で E と E で E と E で E と E で E と E で E と E で E を E に E を E で E に E を E で E に E で E に E で E に E で E に E で E に E で E に E で E に E で E に E で E に E に E に E で E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E に E

モード2でのデータ転送レートは、DDR (Double Data Rate) で2倍、QDR (Quad Data Rate) で4倍もの高速化を実現しています(図7). このモードを実現するため、システムクロック

#### 〔図6〕アローワブルディスコネクトバウンダリ



#### 〔図 7〕 PCI-X 2.0 モード 2 でのデータ転送の例





QDRの場合, 共通クロックの1周期の間に四つのデータを転送する. 1組のストローブ信号は共通クロックの2倍の周波数になり、1クロックにつき四つの立ち上がりエッジを提供する. そして,各ストローブ信号は転送の途中で45度オフセットされる

との同期ではなく、ソースシンクロナスクロック (Source Synchronous Clock) を採用して、クロック信号とデータ信号の わずかなスキューをも排除しています。また電圧も、3.3Vから 1.5V に落として高速化に対応しています。

また、実転送レートを向上させるにあたり、プロトコルの改良も行われ、デバイスIDメッセージ(Device ID Message)というコマンドが追加になっています。これによりデバイス間でピアツーピアのデータ転送が可能になりました。

さらに、バス幅を狭めた16ビットインターフェースも規格化されました。標準の64ビットに対して、設計/製造がより容易に行え、転送レートにおいてもDDRやQDRを使えば、それぞれ533Mバイト/秒や1066Mバイト/秒と高速性を保つことが可能となっています。

なお、PCI-X 1.0 では**表 4**のようにして動作モードを初期化 していましたが、モード 2 ではバスセグメント単位でリセット して再起動しています.

# **4.** PCI-X の実際のバスの動作例

図8に、実際のトレースデータを示します。これはVMETRO 社の PCI-X アナライザを利用してスプリットレスポンス (SpResp)をトリガに設定してトレースしたデータです。

# Clock モード

トレース方法は、Clock モード (Clock の立ち上がりごとにトレース) としてリスト形式で表示しています [図 8 (a)].

(1) Sample「-4」(トリガ位置の4クロック前)でアドレスフェ

#### 〔図 8〕PCI-Xのバストレースデータ表示



(a) Clockモード



(b) Transferモード

ーズがあり、メモリリードブロック (MRdBlk) のトランザ クションがスタートしました.

- (2) Sample [-3]ではアトリビュートフェーズ (Attrib)で、バイトカウント (ByteCnt) は 018 になっているので、リードするデータは 18h バイトであることがわかります。またリクエスタ ID (ReqID) やタグ (Tag) によりリクエスタの情報を表示しています。
- (3) Sample  $\lceil -2 \rceil$  ではターゲットレスポンスサイクル (Tresp) になっています.
- (4) Sample [-1] はコンプリータ側がウェイト状態になっています.

- (5) Sample「TRIG」でトリガがかかった位置です. スプリットレスポンス(SpResp)が返されているのがわかります. つまり, コンプリータがすぐに要求されたデータを用意できないため, スプリットレスポンスを返したわけです.
- (6) Sample「10」ではスプリットコンプレッション(SpComp)サイクルが起きています。コンプリータが先ほど要求されたデータを、自身がリクエスタとなりデータ要求元に転送(ライト)します。リクエスタ ID やタグナンバを確認すると、同一のものであることがわかります。
- (7) Sample「11」ではアトリビュートフェーズが入り, バイトカウントは先ほどと同じ 18h バイトとなっています.

- (8) Sample「13」以降では、コンプリータからリクエスタに対してメモリライトが実行されています。バイトカウントも 4バイトずつ減っているのが確認できます。
- (9) Sample 「18」でこのトランザクションが終了したので、残りのバイト数は 000 となっています.
- Transfer モード

次は、Transfer モード(アトリビュートフェーズとデータフェーズでのみトレース、アイドルやウェイトサイクルはスキップ)でトレースして、スタンダードブロックサイズムーブメントのしくみを確認します。このプロトコルは、128 バイト境界においてのみトランザクションをディスコネクトすることができます[図8(b)].

- (1) Sample「TRIG」でメモリライトブロック (MWrBlk) のトランザクションが実行されていますが、ステータス (Status) がデータから次のステージでアローワブルディスコネクトバウンダリ (DNxtADB) が起こることを伝えています。このときの下位アドレスを確認すると Foh となっています。つまり、この3クロック後にアローワブルディスコネクトバウンダリを実施できます。
- (2) Sample [3]で、このトランザクションはディスコネクトされました.
- (3) Sample「4」で、新しいトランザクションが始まりました. 「3」と「4」のステップ間のタイム差は 6ons なので、新しいトランザクションが始まるまで4クロック分バスが開放されていたことがわかります。バイトカウント (ByteCnt)を確認すると 010 となっているので、残りのバイト数は 10h バイトです。

- (4) Sample「5」で、新しいトランザクションでデータ転送が再開されています。
- (5) Sample 「8」で、このトランザクションが終了しています. このように、バスアナライザを利用すると、各種信号をトレースして、クロックごとの信号状況やステータス、そしてバイトカウントやリクエスタ ID/タグなど、PCI-X で必要な情報が確実に確認でき、デバッグをする際にはたいへん強力なツールとなります

# まとめ

PCIバスに替わる標準バスとして、PCI-X以外にも1Gバイト/秒以上のデータ転送レートをもつシリアルバスが注目されています。これらは各デバイスをポイントツーポイントで結び、PCIやPCI-Xのように、多数のデバイスを同じ信号線を共有するインターフェースとは異なります。

今後は、用途に合わせてバスを選択することが必要になってくるかと思いますが、PCIの特徴である「便利で簡単」にさらに「速い」を付加したPCI-Xは、既存のシステムやボード類の資産をそのまま流用でき、アーキテクチャも流用可能なので、シリアルバスに対しても大きなアドバンテージがあります。

現に、ハイエンドサーバなどでは、現時点ですでに PCI-X が使われてきています。PCI-X の開発支援ツールも、バスアナライザがリリースされており、デバッグや評価の上で、非常に強力にバックアップされています。

本稿が、今後 PCI-X を検討される際の一助になれば幸いです。

むらい・やすひで (株)ミッシュインターナショナル

# Column

66MHz PCI デバイスより, 66MHz PCI-X デバイスの設計が楽なわけ

FPGAであろうが ASICであろうが、デバイス内部のシーケンサやアドレスデコード条件が複雑になればなるほど伝播遅延が増えます。また、出力ピンから実際に信号が出力されるまでにも出力遅延があります。そして、バスの規格としてのセットアップやホールドタイムの規定があります。

PCI バスは同期バスなので、入力信号をそのまま内部のシーケンサなどで使うことができます〔図 A(a)〕. ここであるデバイスの伝播遅延が 10ns、出力遅延が 10ns としましょう. クロック33MHz の PCI バスではセットアップが 7ns と規定されているので、3ns の余裕があることがわかります. しかし、クロックが66MHz になるとどうでしょう. 伝播遅延と出力遅延だけで 20nsになり、このデバイスは66MHz では動作しません.

PCI-Xでは、すべての入出力信号をいったんフリップフロップ

で受けてから出力するように設計します〔図 A (b)〕. このような構造であれば伝播遅延が出力信号に加算されないので、出力遅延の 10ns だけとなり、3ns のセットアップタイムを考慮しても 2ns の余裕が残ります.

井倉将実 来栖川電工(有)

#### 〔図 A〕PCI および PCI-X 対応デバイスの入出力部



# USBハイスピード伝送の実現

桑野雅彦

USB は 1.5 Mbps のロースピードや 12 Mbps のフルスピードから,一気に 480 Mbps のハイスピードまで高速化させるために,ロースピードやフルスピードで 2V 程度あった信号振幅を,ハイスピードでは 400 mV と大幅に小振幅化している.また互換性を重視し,従来の USB ポートに接続しても,フルスピードデバイスとして動作させなければならないため,デバイス内部にはフルスピード用の回路の実装も必要になる.ここでは USB 2.0 対応デバイスのトランシーバ回路やその動作を解説する.

-----

USB2.0では USB1.1 のロースピード (1.5Mbps), フルスピード (12Mbps) に加えて、480Mbps のハイスピードモードがサポートされました。もともと USB は従来の COM ポートやプリンタ,マウス、キーボードなどを代替えするものとして、安価に中低速のデータ転送を行うことを目的として規格化されました。しかし、その後 USB の急速な普及にともない、外部ストレージやビデオキャプチャ関連などへの展開が図られはじめたあたりから、12Mbps という速度に不満が出てきました。さらに IEEE1394 との速度競争などもあり、USB2.0では最高伝送速度が一気に 480Mbps まで引き上げられました。

この段階で、従来との互換性維持のために USB1.1 で使用されていたコネクタやケーブルなどをそのまま流用することや、

下位互換性維持のためハイスピードモードをサポートしている機器では、USB1.1のフルスピードモード、またはロースピードモードもサポートする必要があるなど、デバイス側の設計も複雑なものになっています。

● ハイスピードモードでの大きな変更点

USB2.0では、480Mbpsのハイスピードモードの導入にあたり、信号レベルやデバイスの検出方法からプロトコルにいたるまで大幅な見直しが行われました。これらのうち、今回説明する高速伝送に関わるものでとくに大きなものは、次の五つです。

- (1) トランシーバの内部構成の変更
- (2) 信号レベルの変更(USB1.1 では 3V系. ハイスピードモードは 400mV)

# 〔図1〕ハイスピードトランシーバ回路・



- (3) 信号の終端の導入
- (4) 浮遊容量など基板設計上の規定が厳しくなった
- (5) 信号品質に関してアイパターンによる定義がなされた
- ハイスピードトランシーバ

ハイスピードモードのデバイスは、USB1.x ポートに接続したときにはフルスピードデバイス(12Mbps)で動作することが要求されています。このため、ハイスピードモード対応のトランシーバの内部構造は**図1**(前頁)のような複雑なものとなっています

ハイスピードデバイスはホストと接続されると,まずハイスピード対応可能であるかどうかのネゴシエーションをホスト(あるいはハブ)との間で行い,ハブがハイスピード対応可能という応答をすればハイスピードトランシーバを生かし、非対応であればフルスピードモードのトランシーバを生かすという動作になります。この切り替えは通常 USB コントローラチップ自身で行われますが、ディスクリプタ情報などハイスピードとフル

#### 〔図 2〕USB フルスピード/ロースピードの接続関係



#### 〔図3〕USBハイスピードの接続関係



スピードで切り替えが必要なものもあることから, ハイスピードとフルスピードのどちらで動いているのかということは, CPU で検出できるようになっています.

#### トランシーバの接続関係

フルスピード/ロースピードデバイスの送受信用トランシーバ部分を切り出したのが図2です。フルスピード/ロースピードデバイスでは信号レベルは3.3V系のロジックとほぼ同じで、デバイスの着脱検出用として、ダウンストリーム側(USB ホスト: PC など)では15K $\Omega$ の抵抗でプルダウンして、アップストリーム側(USB ターゲット側)ではフルスピードならD+を、ロースピードならD-を1.5K $\Omega$ でプルアップしています。

一方, ハイスピード時の接続関係は**図3**のようになっています. 一見それほど大きな違いはないようですが, 抵抗の付きかたと値に注目してください.

ハイスピードモードでは、両端がいずれも 45Ω という比較的 小さな値の抵抗でグラウンドと接続されています。これは終端 抵抗と呼ばれているもので、後で説明するとおり高速伝送のためのキーとなっています。終端抵抗は信号が伝送路であるケーブルを通ってトランシーバ IC に入る直前に取り付けられるもので、USB の場合同じ電線を双方向で利用するので、両端に終端抵抗が取り付けられています。

#### 信号レベルの低減

図3からわかるとおり、USB2.0では  $45\Omega$  の抵抗が二つ並列接続されるので、信号線とグラウンドの間の抵抗は  $22.5\Omega$  ということになります。もし、USB1.1 の時のように"H"レベルが 2V 程度必要ということになると、一本あたり 89mA ( $2\div2.5$ )、最大 178mA もの電流が流れることになってしまいます。消費電流の大きさもさることながら、これだけの電流を 480Mbps という高速なレートでスイッチングするというのはかなり難しいことになってきます。また、大きな電流が ON/OFF を繰り返すために不要輻射 (不必要な電磁波の放射)も増えてしまいます。このようすを 20 に簡単に示します。高速な電流を高速度で 2002021 によって高い周波数の不要輻射も増えてしまうわけです。

これらを解決するには、信号レベルの引き下げが有効です. 24(c) にあるように信号レベルを小さくしていけば、その分信号の急峻さもなくなりますし、流れる電流も小さくなり、消費電流や不要輻射などの防止にも効果的です。ハイスピードモードでは信号レベルを 400mV まで引き下げました。これによって信号線に流れる電流は約 17.78mA  $(0.4 \div 22.5)$  まで小さくなっています。

#### • ケーブルと分布定数回路

ハイスピードモードでは終端抵抗が大事な役割を果たすことになるのですが、それではこの $45\Omega$ という値はどうして決まったのか、そもそもなぜ終端抵抗というものが必要なのかということについて、簡単に説明しておきましょう.

まず話を簡単にするため、図5に信号線が1本だけの場合の

#### 〔図4〕信号レベルを下げる効果



(a) ロースピード/フルスピードの電圧レベルとスイッチング



(b) ロースピード/フルスピードの電圧レベルのまま高速化



(c) 電圧レベルを下げて高速化

伝送路のモデルを描いてみました。 ドライバから出た信号が ケーブルを通ってレシーバまで接続された状態を示しています. ここで、Zは後で説明するケーブルの特性インピーダンス、R (終端)が終端抵抗の抵抗値を示しています.

さて、ここでケーブル部分を切り出してみます。ケーブルは 1本の信号線とグラウンド(シールド)で構成されています。信 号線には当然何らかのインダクタンス(誘導性:コイル:成分) が含まれます。また、グラウンドと平行しているので、ここに は何らかのキャパシタンス(容量:コンデンサ:成分)が存在し ます。ケーブルを非常に細かく切り刻んでみれば、信号線に直 列にコイルが、グラウンドとの間にコンデンサが入っているも のが無数に並んだような状態になっているとみなすことができ るわけです。これを回路図のように描いたのが図6です。この ように非常にミクロなデバイスが無数に並んだような状態とし てモデル化される電子回路を, 分布定数回路と呼びます.

分布定数回路のインピーダンスを計算するのはなかなか面倒 ですが、ケーブルの電気的特性が均一に作られていて、単位長 さあたりのインダクタンス(L)やキャパシタンス(C)が一定で あり、またケーブルの直流抵抗分が無視できる場合には比較的 簡単に整理できます.結果は**図6**にも示したとおり,√L/Cで あらわされます。これがケーブルの特性インピーダンスで、こ の値をここではZ(cable)と表しておくことにします.

#### 〔図5〕伝送線路のモデル



#### 〔図6〕LCの分布定数回路



すると,  $Z(cable) = \sqrt{L/C}$ 

#### 〔図7〕信号の反射



#### 信号の反射

ここで**図7**を見てください。いまZ(cable)の特性インピーダ ンスをもったケーブルを信号が伝わってきたとします。最終値 に任意のインピーダンス Z(term) をもった素子がつながってい

た場合、Z(cable) の値とZ(term) の値が等しくないと、到達した信号のエネルギの一部が終端Z(term) で消費されますが、残りはケーブルを伝って戻っていってしまいます。これを信号の反射と呼び、戻っていく信号を反射波と呼んでいます。コップに波を立てると発生した波がコップに当たって跳ね返るのと同じように、段々小さくなりながら行きつ戻りつするわけです。

単発のパルスだけ伝えるような場合には、最初に信号が到達したことだけ分かれば良いようなものですが、実際には変化する信号で情報を伝えているので、この戻ってきた信号が本来の信号と合成されてしまうと、誤動作を引き起こす原因となります。反射してきた信号はそれほど長い時間往復するわけではないので、伝送速度が充分に低速であるうちはそのような早い変化を取り込まないようにすることで対処可能ですが、伝送速度があがってくると、信号と反射波の区別が難しくなっていきます。

Z(cable)とZ(term)が同一である場合には、理論上反射は発生しません。このような状態を「整合が取れた状態」、負荷の値Z(term)を整合負荷、無反射負荷などと呼んでいます。整合をとることを考えて設計することで、(現実には素子の誤差などもあって完璧に一致させることは不可能なので、わずかながら反射は発生するが)実用上問題ないレベルにまで抑えることが可能となるわけです。

この手のケーブルのインピーダンスは一般に数  $+\Omega$  から  $100\Omega$  程度というのが一般的ですので、終端も同じ程度の値の抵抗を使用します。

# • USBバスと終端抵抗

USB バスの場合にはデータ線が2本(D+とD-)あるので 少々ようすが変わってきます. USB では図8のようになってい

### 〔図8〕差動伝送の場合



ます。この場合、終端抵抗の値はケーブルの特性インピーダンスの半分の値にしておきます。 USB ケーブルではインピーダンスは  $90\Omega$  と規定されていたので、終端抵抗は  $45\Omega$  となります。これが、すでに説明した USB の終端抵抗値  $45\Omega$  の根拠です。

USB ケーブルの特性インピーダンスは USB1.1 の時代からすでに  $90\Omega$  と決められていました。ところが、USB1.1 の 12Mbps 程度の伝送速度の場合、かなりいいかげんな値にしていても問題なく伝送できてしまうことから、一部に粗悪なケーブルが流通しており、ハイスピードモードが規格化された当初、この点が問題として掲げられていました。ケーブルのインピーダンスが違っていれば、終端抵抗と不整合になってしまい、反射による影響が出てしまうわけです。

終端抵抗の値が決まり、信号レベルを決めれば流れる電流も 決まってきます。信号レベルを引き下げるほど不要輻射や消費 電流などの面でも有利にはなりますが、一方で外部からのノイ ズの影響など、外乱を受けやすくなってきますので、むやみに 下げると問題が出てきます。このトレードオフでどの程度の信 号レベルにするかが決まってくるわけですが、USB2.0のハイス ピードモードでは 400mV ということにしています。

ちなみに同様に高速なデータ伝送が必要になっているパソコン用 CPU やチップセット間の接続信号も昔は TTL レベルが一般的でしたが、現在では新製品が出るたびに電圧が引き下げられる方向になっています。

#### ● 寄生容量と信号の立ち上がり/立ち下がり

部品としてのコンデンサを取り付けなくても、2本の信号線や信号線とグラウンドの間には必ず何らかのキャパシタンス(容量)が存在します。これを寄生容量と呼びます。**図9**にチップやパターンの寄生容量の存在を図にしてみました。

コンデンサの場合、容量をC(F)とすると、ある周波数f(Hz)におけるインピーダンスは  $1/(2 \times \pi \times f \times C)$ となります、それほど高速ではない信号を扱うときにはそれほど大きな問題とならない寄生容量も、扱う信号の周波数が大きくなると無視できなくなってきます。

コンデンサのインピーダンスが低くなるということは, コン デンサを通る電流が増えるとういことであり, 電流が増えると

# 〔図 9〕寄生容量



いうことは信号として伝わっていく分が減る、すなわち減衰してしまうということになるわけです.

高い周波数成分ほど減衰することから、信号波形も急峻さがなくなり、なまったようなものになってきます. こうなると高速な伝送にとって困ったことになります.

逆に信号波形が急峻すぎる場合には、高い周波数成分も多く、流れている電流も多くなっているので、不要輻射などの発生が懸念されます。とくにロースピード(1.5Mbps)の場合、ケーブルのシールドはしなくてもよいことになっているので、不必要に急峻な波形にすることはできません。

このようなトレードオフの中で、USBでは、

- (1) ロースピードデバイス
  - USB デバイスのドライバ負荷 200pF ~ 600pF の容量負荷 が可
  - ●負荷接続時の立ち上がり/下がりは 75ns ~ 300ns
- (2) フルスピードデバイス
  - ●ドライバ負荷は50pFまで
  - ●立ち上がり/立ち下がりは4~2ons

という規定になっています。さらにハイスピードデバイスの場合には立ち上がり/立ち下がりは500psとなりますが、480Mbpsの伝送ともなるとこの程度の規定では不足なため、より厳密なアイパターンによる定義が加えられています。

#### アイパターン

アイパターンについてはページ数の都合もあり詳しく触れられませんが、USBの規格書から一つだけ例を引き出しておきました(図10). これはドライバが無負荷状態での出力コネクタ部分での規定です。見方は、上下方向が電圧レベルで、左右方向が時間です。電圧が oV を中心にしているのは差動電圧でみているためです。D+とD-の電圧が同じときが oV, D+が+400mV, D-が oV なら+400mV, 逆ならば-400mVということになります。横軸は時間で、0%から100%までが1ビット分の時間です。

図の中央部分に描かれた算盤の玉のような六角形がちょうど「目」のように見えるので、アイパターンと呼ばれます。信号の変化がこの目の内側を通らないようにしなくてはならないというのがその規定です。

イメージとしてはオシロスコープで伝送波形を見ている状態です。高速に伝送していると、伝送波形がひっきりなしに動いていることになりますが、ディジタル信号である以上、'1'か'o'かが確実に確定している時間があるため、輝線で真っ白にはならず、ぽっかりと穴があいたような場所ができます。アイパターンはこの穴の形状が最小でもこれだけなくてはいけないという規定に相当します。

また実際の波形写真としては、次号以降に掲載予定の『USB compliance Test の概要』が参考になるかと思います.

USB の仕様書ではさらに細かく場合分けされたアイパターンが指定されており、480Mbps の高速伝送を確実に行うためのガ

#### 〔図 10〕 USB ハイスピードのアイパターン例



イドラインとなっています.

#### • ケーブルスキュー

USB は二本のデータ線 (D+2D-)を利用し、通常は片方が" H"レベルならもう一方は" L"レベルにするという差動伝送を行っています (ただし、リセットなど特殊な条件を作るため両方" L"や両方" H"という状態になることもある). レシーバはこの両方のデータ線の電位差を見て" 1"か" 0"かを判定しているので、もし、このとき D+2D-00到達時間に差ができてしまうと、データを誤読する可能性がでてきます。

この両者の到達時間差をスキューと呼びます. USB ケーブル の場合, データ線のスキューは 100ps 以下になるよう規定されています.

:

USB2.0ではハイスピード対応のため、この他にも細々した 規定が付け加えられています。あくまでも下位互換性を維持し ながらハイスピード伝送に対応するためにさまざまな工夫がな されているので、興味ある方はさらに細かい部分まで調べてみ ると面白いでしょう。

**くわの・まさひこ** パステルマジック

# IEEE1394.b 最新動向

# 北山洋幸

# はじめに

現在ではIEEE1394.a-2000 に準拠したインターフェースが、多くのパソコン、ディジタル家電、ハードディスク、およびFAネットワーク機器などに搭載されています。USB2.0 が出現し、IEEE1394.a-2000の速度面での優位性はなくなりました。とはいえ、USB2.0 はやっと出回ったところです。ノートパソコンでは、やっと USB1.1 から USB2.0 へ移行が始まったばかりです。このような状況や使用目的の違いから、IEEE1394と USB は併用されています。

IEEE1394は IEEE1394.b の出現により、やっと普及が始まった USB2.0 と比較して、速度や距離で再び優位に立ちました。すでに IEEE1394.b 対応の 800Mbps の製品が出荷され始めました。現在は 800Mbps の製品が出始めたばかりですが、IEEE1394.b は最高 3.2M bps まで規格されています。近い将来には、より高速な製品が現れることでしょう。もっとも IEEE1394.b が発表されてから、すぐに製品が現れたわけではありません。最近になって、やっと LSI やそれを採用した HDD などが現れ始めました。

IEEE1394.b にはネイティブのベータ (beta) モードと、既存の IEEE1394-1995, および IEEE1394.a-2000 と 互換性がある, バイリンガル (bilingual) モードの二つが用意されます. 速度も新たに 800Mbps, 1.6Gbps, 3.2Gbps が追加されました. 不評だった距離の問題も解決されています. しかし、ケーブルやコネクタの種類は増え、既存の IEEE1394 で使われていたコネクタやケーブルとの組み合わせを考えると、組み合わせは少々複雑になりました.

# 従来までのIEEE1394

IEEE1394の最初の技術仕様が完成したのは 1987 年頃です. この 仕様は 1995 年に正式に IEEE Std 1394-1995 として認められました. 2000 年には、 IEEE1394 インターフェース規格の補完・拡張規格で ある IEEE1394.a が IEEE Std 1394.a-2000 として採択されました. 追 加されたおもな特徴としては、4 ピンコネクタやバスリセット動作の 安定化、ショートバスリセット(バスリセットの時間を短くする機

#### 〔表 1〕IEEE1394-1995 に対する IEEE1394.a-2000 の特徴

- ●4ピンコネクタの追加
- ●バスリセット動作の安定化
- ●ショートバスリセット(バスリセットの時間を短くする機能)の追加
- PHY の低消費電力化(サスペンド状態などの追加)

#### 〔表 2〕IEEE1394.b で追加されるおもな特徴

- ●高速化(800Mbps~3.2Gbps)
- ●長距離化(~ 100m)
- ●伝送媒体の追加(石英ファイバ,プラスチックファイバ, UTPなど)
- ●光ファイバのための仕様の追加(初期化の方式, 符号方式など)

能)、物理層の低消費電力化 (サスペンド状態などの追加) などが挙げられます (表1).

USB2.0 の出現により、IEEE1394.a-2000 の速度面の優位性はなくなったと考える人もいますが、USB2.0 はあくまでもパソコンをおもなマーケットとしており、IEEE1394 と用途が異なります。このためIEEE1394 と USB は共存していくと思われます。USBでもピアツーピア接続に対応できるように、USB2.0 の補完規格として USB On-The-Go (OTG)が策定されましたが、OTG 対応を正式にうたった製品の登場はこれからという状況のようです。

# ● IEEE1394.b で改善されたおもな点

IEEE1394-1995 から IEEE1394-a-2000 への変更はそれほど大きなものではなく、問題を引き起こしていたバスリセット期間の短縮や 4 ピンコネクタの追加でした。それに比較して、IEEE1394-b では大きな変更がいくつもあります。まず、従来の DS ポート (DS/LINK) に  $\beta$  ポート (ベータポート、8B10B 符号化) が追加されました。メディアもたくさん現れ、それと同時にコネクタ形状も複数現れました。性能 (とくにスループット) を向上させるために、アービトレーションもデータ転送と平行して行えるようになりました。また不満の多かった距離の問題も解決されました (表2).

高速化は単純なスピードの高速化だけでなく、スループットも考慮されています。従来のIEEE1394で課題だった、ギャップによるアービトレーションでは、速度をいくら速くしてもバスを効率的に使用することはできません。そこでアービトレーションの方法を根本的に変更しました。また、転送速度の高速化に伴い、符号化を従来のDS/LINKから実績のある8B10Bへ変更しました。

#### • アービトレーション

IEEE1394.bでは、既存のIEEE1394と違い、アービトレーションをデータの送信と平行して行えるようになりました。今までのIEEE 1394ではデータの送受信が終わった後に、アービトレーションを行っていたためバスを有効利用できない時間帯がありました。しかし、IEEE1394.bでは、データの送受信を行っている最中にアービトレーションを行います。このため、データの送受信が終わって、すぐに次のデータの送受信を行うことができます。これによりバスの使用効率が高くなります。

#### ● 符号化の変更

IEEE1394bでは、データの符号化に Gigabit Ethernet や Fibre Channel で使われている 8B10B を使うようになりました。既存の 1394 で使われていた DS/LINK は使用していません。8B10B については、第4章のコラム 2(p.89) を参照してください。

-般的に、上記のアービトレーションと符号化を採用したモードを 「ベータモード」と呼び、従来のモードをレガシーモードと呼びます。

IEEE1394.bでは、スピードと距離の関係が、今までのように単純ではなくなりました。そこで表に距離、速度、およびメディアのマトリックスを表3に示します。

#### 互換性

IEEE1394.b では転送の符号化も違うし、コネクタの形状も異なるため、これまでのポートにそのままで接続することはできません。800MbpsのIEEE1394.b では9ピンのコネクタが使われます。この9ピンのコネクタと、従来からある4ピン、6ピンを9ピンコネクタに接続するためのケーブルが用意されます。また、IEEE1394.b では純粋なIEEE1394.b の規格であるベータモードと、下位互換性を保証するためのレガシーモードが用意されます。

#### • 製品動向

USB2.0 はすでに一般的なものになりつつあります, それに比べ IEEE1394.b はまだまだ普及しているとはいいがたい状況です.

IEEE1394.b 対応のパソコンとしては、アップルの新 G4 Mac があげられます。800Mbps の IEEE1394.b (アップルでは FireWire800 と表現) と同時に 400Mbps の IEEE1394.a と USB2.0 も搭載しています。

Macworld Conference&Expo/San Francisco 2003 (2003 年 1 月 7 日~ 10 日)で、いくつかのベンダから 800Mbps (IEEE1394.b)の対応の外付け HDD が発表されています。これらは、ほとんどが、Oxford Semiconductor 社 (http://www.oxsemi.com/)の IEEE1394.b コントロールチップ OXUF922 を搭載したインターフェースボードを採用しているようです。OXUF922 は IEEE1394.b だけでなく USB2.0

#### 〔表3〕各種メディアと距離、速度

| メディア | 100Mbps | 200Mbps | 400Mbps | 800Mbps | 1600Mbps | 3200Mbps |
|------|---------|---------|---------|---------|----------|----------|
| STP  | 4.5m    | 4.5m    | 4.5m    | 4.5m    | 4.5m     | 4.5m     |
| UTP  | 100m    | -       | _       | _       | _        | _        |
| POF  | 50m     | 50m     | _       | _       | _        | _        |
| HPCF | 100m    | 100m    | _       | _       | _        | _        |
| GOF  | 100m    | 100m    | 100m    | 100m    | 100m     | 100m     |

STP : gピンシールドツインスペアケーブル UTP5 : CAT-5 UTP (ISO/IEC 11801 ch.7) POF : Step-index プラスチック光ファイバ HPCF: Hard Polymer Clad 光ファイバ

GOF :ガラス光ファイバ

にも対応しています. このため発表されたほとんどの HDD が IEEE1394.b と USB2.0 を搭載しています. Oxford Semiconductor 社は IDE ブリッジで有名な会社です. OXUF922 以外にも, いくつものブリッジ LSI や評価ボードを販売しています.

HDD に関しては日本でも、ロジテックから FireWire 800 に対応したモデルが発表されています (写真  $\mathbf{1}$ ).

ほかにも数社が64ビットPCIを用いたIEEE1394.bボードの販売を進めているようですが、本原稿執筆時点では、「玄人志向」のIEEE

#### 〔図 1〕IEEE1394.b 対応 PHY デバイス TSB81BA3



#### [写真 1] IEEE1394.b に対応した HDD (ロジテック製)





(b) IEEE1394.b 対応 9 ピンコネクタ

(a) 外観

1394B-PCI64 が現れているのみです(今後も安定供給が続くか不明だが). この PCI ボードは、LINKに Indigita 社 (http://www.indigita.com/)の iND60C20 が、PHYに TI社の TSB81BA3A が使われています。64/32 ビット PCI に対応し、9 ピンのバイリンガルを 3 ポート装備しています。

#### • LSI

IEEE1394.b 対応の LSI もやっと入手可能になりました。先に述べた,Oxford Semiconductor 社の LSI もありますが,このチップは IDE ブリッジとして設計されています。よって IEEE1394.b のアプリケーションを開発するには向きません。

テキサス・インスツルメンツから IEEE1394.b のリンク層 (LINK) チップとして TSB82AA2 が、物理層 (PHY) チップとして TSB81 BA3 が販売されており、これが現時点で使える IEEE1394.b 対応 LSI といえるでしょう.

TSB81BA3 は、3 ポートのバイリンガル PHY デバイスです(**図 1**, 前頁). 最高 800Mbps に対応した、IEEE1394.b 標準規格準拠製品です。この TSB81BA3 は前世代の IEEE1394-1995 や IEEE1394-a-2000の 2 倍の速度を実現するだけでなく、伝送距離を最高 100m まで延長しています。また、従来の IEEE1394-a-2000 への下位互換性を備え、DS/LINK 符号化方式、ならびに IEEE1394.b の 8B/10B 符号化方式をサポートします。

この PHY と対で使用する LINK デバイスが TSB82AA2 です (**図 2**). TSB82AA2 は、OHCI(オープンホストコントローラインターフェーイス) 1.1 規格に準拠するとともに、OHCI1.2 にも対応します。OHCI

#### 〔図 2〕IEEE1394.b 対応 LINK デバイス TSB82AA2



はパソコンだけでなく、組み込み機器でも広く使われるようになり ました。このOHCI 規格は、より高速のアシンクロナスおよびアイ ソクロナスデータ伝送、アドバンスドパワーマネジメント機能をサポ ートしています

#### ● IEEE1394.b では PCI バスがネック

IEEE1394.b 対応の周辺機器が発表されないのは、単純にLSIの供 給遅れだけではない問題があります。現在のパソコンではすでにか なり前から CPU は GHz 帯に入っています。 CPU やビデオまわりは、 ずいぶんと高速化が図られました. しかし、I/Oとなる PCI インタフ ェースは相変わらず 32 ビット/33MHz が使われています. しかも, このバスは汎用なので、一つのデバイスが占有して全バンド幅を使 うわけではありません、そう考えると、IEEE1394.b で追加されたも っとも遅い速度である800Mbpsさえ、PCIバスがボトルネックとな る可能性が高いのです、つまり、現在のパソコンアーキテクチャで はIEEE1394.b の性能を使い切ることは簡単なことではありません. 現在のパソコンであれば IEEE1394.a で十分な性能を提供していると 言えるでしょう.

同じような問題がシリアル ATA や Gigabit Ethernet 注1にも存在 します、これらはチップセットへ組み込まれるのではないかと言われ ています. ところが IEEE1394b に関しては、パソコンへどのように 搭載されるのか明確ではありません。このあたりが IEEE1394b 製品 が現れない一因でしょう

筆者の会社においても、すでに IEEE1394.b の開発キットのプロト タイプは完成していますが、いまひとつ本格的な販売に移れない要 因がここにあります。もっとも簡単な方法は64ビットPCIを使う方 法ですが、これではマザーボードが限定されます。性能は発揮でき なくても32ビット作った方が使いやすいのだろうかと思案中です.

いずれにしても、IEEE1394.b の性能をパソコンユーザーが十分に 引き出すにはチップセットに入るか、PCI Express などを待たなけれ ばないのでしょう、800Mbpsで、この状態です、1.6Gbpsや3.2Gbps では、小手先の対応では性能はバスネックになり、ほとんど性能を 発揮することはできないでしょう.

もっとも IEEE1394b の応用はパソコンだけに限られているわけで はありません. FA や組み込み分野では、距離を伸ばしたいユーザー も多いので、しばらくは速度よりそちらに応用される可能性が高い と思われます。実際、車などでIDB-1394(車載用規格)の検討も進ん でいます. FAネットワークでも距離に不満が出てたので、そちらが パソコンより先に IEEE1394.b へ興味を示す可能性は高いと予想でき ます

きたやま・ひろゆき (有)スペースソフト http://www.spacesoft.co.jp/

注1:インテルは Gigabit Ethernet とのインターフェースとして CSA をチップセットに組み込むことを発表した.CSA (Communication Streaming Architecture) のバンド幅は PCI の 2 倍である 266M バイト/秒. CPU とメモリを制御するノースブリッジに直結されるようだ.

#### Column

IEEE1394.bのコネクタとケーブル

IEEE1394.b 専用のコネクタをベータポート、従来の 400Mbps 以下のスピードの信号も接続できるコネクタをバイリンガルポー トと呼びます、図AにIEEE1394.bのソケット形状を、表Aにピ ン配置を示します。図 A を見るとわかるように、ベータポートは でっぱりの部分が広く、バイリンガルポートは狭くなっています. よってベータソケットにはバイリンガルコネクタは入りません. 逆にバイリンガルソケットにはベータコネクタが入るので、 IEEE1394.b ネイティブで接続するケーブルは、両端がgピンの ベータコネクタになっています.

#### 〔表 A〕 IEEE1394.b 対応 9 ピンコネクタ配置

| ピン番号 | 名 称            |
|------|----------------|
| 1    | ТРВ —          |
| 2    | TPB +          |
| 3    | TPA -          |
| 4    | TPA +          |
| 5    | TPA用ツイストペアシールド |
| 6    | GND            |
| 7    | NC             |
| 8    | $V_{pp}$       |
| 9    | TPB用ツイストペアシールド |

またバイリンガルポートには従来の6ピンや4ピンの信号も接 続できることになるので、IEEE1394.b 対応のケーブルには、次 のようなバリエーションができることになります.

- ●ベータ対ベータを接続
- →両端バイリンガルコネクタのケーブル
- ●ベータ対バイリンガルを接続
- →両端バイリンガルコネクタのケーブル
- バイリンガル対バイリンガルを接続
- →両端バイリンガルコネクタのケーブル
- バイリンガル対6ピンを接続
- →片端バイリンガル-片端6ピン
- ●バイリンガル対4ピンを接続
- →片端バイリンガル-片端4ピン

#### (図A) IEEE1394.b 対応9ピンソケット形状





(b) バイリンガルソケット

# 10 Gigabit Ethernet の 技術動向

松本信幸

Gigabit Ethernet 対応の LAN カードやハブが安価で入手できるようになってきた. ブロードバンドの普及もあり、ネットワークの高速化の要求は今後もますます高まるだろう. 最後の章は、今回取り上げたバス/インターフェースの中でももっとも長い伝送距離を高速に通信することを考えた、Gigabit Ethernet および 10 Gigabit Ethernet の技術動向について解説する. (編集部)

10Gigabit Ethernet は、IEEE802.3 委員会が検討している、Ethernet の流れの上にある高速インターフェースです。ネットワーク上でやり取りされる情報の多様化や、その量の増大に対応するために、初期の Ethernet から見ると、動作メカニズムは大幅に変化しています。

#### • Gigabit Ethernet

Ethernet の速度は、10倍ずつ速くなっています。おもなものとして(過去には1Mbps などというものもあったが)10Mbpsである10Base-T/5があり、次に現在もっとも多く出回っている100Base-TXが続きました。ネットワーク利用者の増加にともない、回線の容量や中継を行う機器のスイッチング能力が増大しましたが、ネットワークの能力の増大はアプリケーションなどの変化を呼び、回線容量のさらなる増加を要求しました。

こうして誕生した技術が Gigabit Ethernet です. とはいえ、アプリケーションに変化が出たといっても、回線容量が増加する最大の要因はネットワーク利用者の増加にあるので、Fast Ethernet 以下の速度をもつ端末を収容し、基幹部分として利用されることが主目的となります。初期に市場に出た、端末側に10Mbps インターフェースのスイッチング HUB がもつアップリンク用のインターフェースが Fast Ethernet だったようなものです。端末側のインターフェースが Fast Ethernet になってし

まったため、再びアップリンクの容量が足りなくなり、10倍の 速度をもつ Gigabit Ethernet が必要になりました。ほかにも、 その時代の状況に応じていくつか派生していますが、本流は基 本に忠実なものとなっていました(図1).

ここまではLANの話なのですが、もう一つの要因としてLANからみて外部へのアクセスが激増したということもあげられます。LANから見て外部へのアクセスは、昔は全体の2割程度で、8割は内部の通信でした。しかし、現在では逆転どころかそのほとんどが外部との通信となっています。もっともこれにはメールサーバなどを社外の事業者に委託しているなどという運用形態の変化も要因の一つです。

こうして高速化していくインターフェースですが、単に動作クロックを早くすればよいというものではありません。信号とノイズの区別がつきにくくなったり、伝送速度によって距離に制限を受けたりという物理的な制約が障壁となって現れてきます。これらに対処するため、Gigabit Ethernet では目的に応じて複数のインターフェースを用意するようになっています(表1).

これは、一部例外はあるものの、大きく「構成の変更がほとんどない長距離(正確には中距離)伝送用」と、「頻繁に接続変更が可能な至近距離用」に分けられています。前者の検討を行っていたのがIEEE802.3zで、後者がIEEE802.3abです。

#### 〔図 1〕10Gigabit Ethernet への流れ



#### 〔表 1〕 4 種類の Gigabit Ethernet

| 1000Base-CX | スイッチングクローゼットやコンピュータルーム<br>などの室内で用いる |
|-------------|-------------------------------------|
| 1000Base-T  | おもにフロア配線に用いる(アクセス系)                 |
| 1000Base-SX | 低価格光通信用. フロア配線および小規模バックボ<br>ーンに利用する |
| 1000Base-LX | キャンパスレベルのバックボーンに利用する                |

#### 〔表 2〕Gigabit Ethernet における伝送距離

|             | ファイバ |        | 伝送距離 |  |  |
|-------------|------|--------|------|--|--|
| 1000Base-SX | MMF  | 62.5um | 275m |  |  |
| 1000Base-LX | MMF  | 62.5um | 550m |  |  |
| 1000Base-SX | MMF  | 50um   | 550m |  |  |
| 1000Base-LX | MMF  | 50um   | 550m |  |  |
| 1000Base-LX | SMF  | 9um    | 5km  |  |  |

|             | ケーブル形状     | 伝送距離 |  |  |
|-------------|------------|------|--|--|
| 1000Base-CX | シールドケーブル   | 25m  |  |  |
| 1000Base-T  | ツイストペアケーブル | 100m |  |  |

IEEE802.3z で検討されていたインターフェースには、光ファ イバケーブルを用いるものと同軸ケーブルを用いるものの2種 類がありますが、後者の同軸ケーブルを用いるインターフェー スである 1000Base-CX はケーブル長が最大で 25m と短く、用 途も限られているためほとんど市場に出ていません.

前者の光ファイバケーブルを用いるものには、短波長の光(波 長が 1000nm 未満の短い波長の光: 850nm) を用いる 1000Base-SX と、長波長の光(波長が 1000nm 以上の長い波長の光: 1310nm) を用いる 1000Base-LX があります.

利用方法の差は、1000Base-LX が長距離用で、1000Base-SX が多少安価な中短距離用となっています(表2).

しかし、スイッチ間の接続であれば光ファイバを用いても大 して問題はありませんが、接続する相手がサーバとなると配線 はフロア内となりますし、接続の変更(装置の移動などによる) も考えられます。多くの場合、光ファイバケーブルの取り扱い ができる人のいない場所で利用されることが考えられるので、 レイアウトの変更などが容易に行えるインターフェースが必須 であり、IEEE802.3ab として 1000Base-T が検討されました.

これは、従来の 10/100Base-TX で利用している RJ-45 コネク タを利用するものです。おもに中継装置間に用いる IEEE802.3z と異なり、端末接続を想定しているIEEE802.3abでは、 Ethernet の代名詞ともいえた CSMA/CD(Carrier Sense Multiple Access with Collision Detection) 方式も検討されてい ます。しかし、従来と同じ構成では運用面に無理があるので、 「キャリアエクステンション」、「フレームバースト」といった対 応も選択肢として加わっています.

#### ● CSMA/CD方式の限界

Ethernet といえば、もともとは1本の同軸ケーブルに複数の 端末を接続し、通信を行うための環境を提供するものであり、

〔図 2〕 CSMA/CD 方式



ネットワーク上にマスタのいない状況で各々の端末が自立的に 通信を実現するものでした. そして, その動作を実現するカギ となる手法が CSMA/CD 方式でした。

CSMA/CD方式とは、ネットワークに対してデータを送出す る際、ネットワーク上にほかからのデータがないことを確認し たうえで送出を開始します. また, データの衝突が発生した場 合はそれを検出できるようになっており、そのときはデータの 送出を停止し、ある程度の時間待ってから再送を開始します (図2).

ここでインターフェースの速度が高速化していった場合を考 えてみると、たとえば速度が10倍になるということは、逆に同 じデータ量を送るための時間が10分の1になるということで す. 電気信号(または光であっても)には速度がある以上,ケー ブル内を進むのにも時間を要します。時間が10分の1になると いうことは、信号が進む距離も10分の1になってしまいます (図3).

つまり、インターフェースの速度が増加するにつれて、 CSMA/CD 方式の動作できる範囲は小さくなっていきます。先 のキャリアエクステンションは、Gigabit Ethernet の 25m とい う CSMA/CD上の距離制限を,200mまで延ばすために用いま すが、このように特別に手を打たなければ、従来のままでは利 用できなくなっているのが現状ですし、この手もこれ以上の速 度の増加には対応できません.

事実上, Ethernet における CSMA/CD 方式の利用は, IEEE802.3ab 以降,対応をあきらめています。しかも,現実問 題としては CSMA/CD 方式は伝送路のリソースをむだ遣いす るので需要は少なく、IEEE802.3abにおいても、キャリアエク ステンションやフレームバーストは「選択肢」でしかなく、現状 でもほとんど利用されていません.

# 特集 高速バスシステムの徹底研究

#### 〔図3〕コリジョンドメインの変化



#### 10Gigabit Ethernet

利用者の増加とアプリケーションの変化は、Ethernet を LAN (限定範囲内)のネットワークからインターネットへと変化を促しました。最大の特徴は、通信相手との距離が桁違いに遠くなったということになります。その場合の影響をもっとも受けるのは伝送距離です。ネットワークの利用形態が同じで、アプリケーションにのみ変化がある場合、問題となるのは帯域だけですが、利用形態そのものに変化が出る場合、伝送距離も、より遠くに伝送できるものが必要となります。

10Gigabit Ethernet は, Gigabit Ethernet のうち IEEE802.3z をさらに発展させたものとして, IEEE802.3ad として検討され ました. Gigabit Ethernet で利用された短波長(1000Base-SX)

#### 〔表 3〕10Gigabit Ethernet のインターフェース分類

|                   | 10GBase-SR | 10GBase-SW | 10GBase-LX4                           | 10GBase-LW4  | 10GBase-LR | 10GBase-LW | 10GBase-ER | 10GBase-E |  |
|-------------------|------------|------------|---------------------------------------|--------------|------------|------------|------------|-----------|--|
| ンターフェース条件         |            |            |                                       | •            |            |            |            |           |  |
| 伝送路速度(L1) (MHz)   | 10,312.50  | 9,953.28   | 3,125 × 4                             | 2,488.32 × 4 | 10,312.50  | 9,953.28   | 10,312.50  | 9,953.28  |  |
| 利用波長数             | Se         | rial       | WWDM(×4)                              |              |            |            |            | erial     |  |
| データ伝送能力(L2)(Mbps) | 10,000     |            | 10,000                                |              | 10,000     |            | 10,000     |           |  |
| 基準波長(λ) (nm)      | 88         | 50         |                                       |              |            | 1310       |            | 1550      |  |
| フレームフォーマット        |            | OC-192c    |                                       |              |            | OC-192c    | OC-1920    |           |  |
| コーディング            | 64B66B     | 64B66B     | 8B10B                                 |              | 64B66B     | 64B66B     | 64B66B     | 64B66B    |  |
| Transmitter Type  | VC         | SELs       |                                       |              | LAS        | SER        |            |           |  |
| 光パワー              |            |            |                                       |              |            |            |            |           |  |
| 最大光量 (dBm)        | - 4        |            |                                       |              | 0          | - 3        |            |           |  |
| 最小光量 (dBm)        | <b>-</b> 9 |            |                                       |              | - 5        | - 8        |            |           |  |
| 最大受光感度 (dBm)      |            |            |                                       |              | 0          |            |            |           |  |
| 最小受光感度 (dBm)      | - 17       |            |                                       |              | - 14       |            |            |           |  |
| 使用光ファイバ種別(1)      |            | _          | SMF                                   |              |            |            |            |           |  |
| 最大伝送距離 (m)        |            |            |                                       | 10           | 0,000      |            | 40,0       | 000       |  |
| 使用光ファイバ種別(2)      | M          | MF         | _                                     |              | _          |            | _          |           |  |
| コア/クラッド径          | 62.5       | 7/125      |                                       | _            | -          | _          | - / -      | _         |  |
| モーダルバンド幅(MHz×km)  | 1          | 60         | _                                     |              | _          |            | _          |           |  |
| 最大伝送距離 (m)        | 2          | 28         | _                                     |              | _          |            | _          |           |  |
| 使用光ファイバ種別(3)      | M          | MF         | _                                     |              | _          |            | _          |           |  |
| コア/クラッド径          | 62.5       | 5/125      | _                                     |              | _          |            | _          |           |  |
| モーダルバンド幅(MHz×km)  | 2          | 00         |                                       | _            | -          | _          |            | _         |  |
| 最大伝送距離 (m)        | :          | 35         |                                       |              |            | _          | _          |           |  |
| 使用光ファイバ種別(4)      |            | _          | M                                     | MMF          |            | _          |            | _         |  |
| コア/クラッド径          |            | _          |                                       | 62.5/125     |            | _          |            | _         |  |
| モーダルバンド幅(MHz×km)  |            | _          |                                       | 500          |            | _          |            | _         |  |
| 最大伝送距離 (m)        |            | _          |                                       | 300          |            | _          |            | _         |  |
| 使用光ファイバ種別(5)      |            | MMF        |                                       | F            |            | _          |            | _         |  |
| コア/クラッド径          |            | 50/125     |                                       |              | _          |            | _          |           |  |
| モーダルバンド幅(MHz×km)  |            | 400        |                                       |              |            | _          |            | _         |  |
| 最大伝送距離 (m)        | (          | 59         | 240                                   |              | _          |            | _          |           |  |
| 使用光ファイバ種別(6)      | MM         |            | · · · · · · · · · · · · · · · · · · · |              | _          |            | _          |           |  |
| コア/クラッド径          | 50/125     |            | 125                                   |              |            | _          | -          | _         |  |
| モーダルバンド幅(MHz×km)  | 500        |            | 00                                    | _            |            | _          | _          |           |  |
| 最大伝送距離 (m)        | 86         |            | 300                                   |              | _          |            | _          |           |  |
| 使用光ファイバ種別(7)      | MMF        |            | _                                     |              | _          |            | _          |           |  |
| コア/クラッド径          | 50,        | /125       |                                       |              | _          |            |            |           |  |
| モーダルバンド幅(MHz×km)  | 2000 (     | 次世代)       |                                       | _            | -          | _          | _          |           |  |
| 最大伝送距離 (m)        | 3          | 00         |                                       | _            | _          |            | _          |           |  |

7

と長波長 (1000Base-LX) のほかに、1000Base-LX で利用された 1310nm 帯のものよりさらに波長の長い 1550nm 帯が追加されています。このインターフェースは長距離伝送に用いるもので、最大 40km までの伝送を可能としています。

また、1310nm帯では、波長多重である DWDM を用いたものも加わっています。1310nm帯の DWDM を含めて 4種類の波長を用いるようになっているうえに、その各々において 2種類のフレームを定義しているので、大枠 8種類のインターフェースから目的に応じて使い分けられるようになっています (表3).

#### • インターフェース別の分類

10Gigabit Ethernet におけるインターフェース種別の表現も, 従来と同じような表記方法となっています(図4).

通常、最初の数字は伝送路の速度を Mbps 単位で表しています。10Mbpsの Ethernet では10で、1Gbpsの Gigabit Ethernet は1000Mbpsとして「1000Base ......」として表しています。しかし、10Gbpsになると10000となってしまうため、さすがに見にくいものとなり、変えることになりました。しかし10k・Mbpsという解釈もこれまた変なので、「10GBase ...」となっています。つまり、従来と同じような表記方法を用いてはいますが、従来の Gigabit Ethernet までが数字 + Mbpsであったことに対して、10Gigabit Ethernet では数字 + bpsとなっています。中央の「Base」は相変わらずベースバンド方式のことであり、このあたりに変化はありません(というか変わっていないのはここだけか?)。最後に、「-」の後にインターフェースの特徴を

#### ータによって示されます. ● 利用する波長の表示

最初が、利用する光の波長を示しており、S、L、Eの3種類があります。このうち、SとLは Gigabit Ethernet と同じ短波長(850nm)と、長波長(1310nm)を示します。Eは、これまた長波長に分類されるのですが、1310nmよりさらに波長が長くなる 1550nm 帯域を利用するものです(図  $\mathbf{5}$ ).

示す記号が入りますが、10Gigabit Ethernetでは三つのパラメ

#### • フレームフォーマットの表示

二つ目のパラメータはフレームフォーマットとして、現実に 伝送できるビット量などを示すものとして利用され、X、R、W があります. X は、Gigabit Ethernet や Fast Ethernet でも利用されていますが、伝送しようとする情報を8ビット-10ビット (8B10B)変換する場合に用いられます。8B10B変換では、8ビットの情報を10ビットのコードに変換して伝送しています。このため、実際に伝送しようとする情報よりも、より多くのビット列を伝送しなければならなくなってしまいます。

実際、Gigabit Ethernet でも 最後に Xのついている 1000 Base-LX/SX/CX では現実の速度は 1250Mbps で伝送されています。 ちなみに X のついていない 1000Base-T では 1000Mbps で伝送されています。

次にRですが、これはXと同じような手法を用いるものの、もう少し効率を良くしたものとなっています。つまりコードへ

#### 〔図 4〕 10Gigabit Ethernet におけるインターフェース種別の表現





の変換を 64B66B 変換としているのです。このため X で 25 %ものオーバヘッドがあったものが、3 %強まで減っているので、伝送路の速度をあまり大きくせずに済むようになります。この場合の実際の速度は、10,312.5Mbps となっており、64B66B 変換したとしても情報の伝送能力は 10Gbps を確保しています。

最後にWですが、10Gigabit Ethernet は拠点間通信を想定している関係上、従来までの伝送設備との整合性も考慮に入れており、Wはそのような設備を使用するために用意されたものです。つまり、SONET系のインターフェースとなっています。SONET系で10Gbps にもっとも近い9.6Mbpsである、OC-192cのフレームフォーマットを利用します。しかし、OC-192cの9.6Mbpsにはフレームのヘッダ情報を含むので、実際に伝送できる能力は、10Gbps に届きません。

#### 波長多重の有無

最後のパラメータは、そのインターフェースが DWDM を行う際の波長の多重数を示していて、数字が入ります。種類は DWDM を行わず、一つの波長を使っているオーソドックスな場合(シリアルと表現している).

この場合、数字としては $\lceil 1 \rceil$ が入ることになるのですが、表記において $\lceil 1 \rceil$ は省略できるので、DWDMでない場合はインターフェースの種別を示すパラメータは二つだけとなります。実際に数字が入るケースは $\lceil 4 \rceil$ だけで、それ以外は想定されていません。

### Column

10Gigabit Ethernet のニックネーム?

Ethernet の発展は、10Mbps の Ethernet から、10 倍である 100Mbps の Fast Ethernet となり、さらに 10 倍の 1Gbps (1000Mbps) の Gigabit Ethernet が登場しました。この間の頭文字は「E」、「F」、「G」と来たため、続く 10Gigabit Ethernet では、絶対に「H」を頭文字とするニックネームに決まると心から信じていました。しかし結果は、何のひねりもなく「10Gigabit Ethernet」や「10Gig:テンギグ」と呼ばれています。残念です……?

ここの注意点は、四波長多重を行っているからといって、伝送能力が40Gbpsになるわけではありません。じつは逆で、2.5Gbpsを四波長(四色という言い方もする)並列にすることによって、結果10Gbpsの速度を実現しているのです。

#### • インターフェースの注意点

インターフェース種別を示すパラメータは3種類あり、それぞれが3, 3, 2個の選択肢をもっているので、そのまま考えれば18種類の組み合わせが考えられます。しかし、実際はそれほど多くはなく、8種類しか規定されていません。一例を示すと、フレームフォーマットに関してですが、64B66Bがあるにも関わらず、8B10Bを用いるメリットとは何でしょうか?

3%そこそこで済むオーバヘッドを25%にすると、その分回線の速度を上げねばならず、実際には12.5Gbps などという速度にしなければなりません。したがって、[X]によるフォーマットはなぜあるかといえば、波長多重を行うインターフェースで用いられているのです。

これらの存在は、10Gigabit Ethernet を作り上げる過程で、過去の技術を流用して段階的に実現してきたためにあるのです。このため、現在市場に投入されているインターフェースとしては「S, L, E]と「R, W」の組み合わせと考えて問題ありません(勧告上は、これらに LX4と LW4 が加わって 8 種類となる).

もう一つの問題は、インターフェースの種類による実質上の 速度差です。 10Gigabit Ethernet は「10Gbps のインターフェース」を提供するものです。

10Gigabit Ethernetにおける速度差とは利用するフレーム そのものが異なり、それに起因して伝送速度に僅かな差が生じています。よって、10/100Base-TXのようなオートネゴシエーションとは条件が異なります。結論をいえば、10GBase-ERと10GBase-EWでは、同じ1550nm帯域の光を用いてシングルモード光ファイバにより接続される10Gigabit Ethernetのインターフェースであるのですが、通信できません。というかそもそもリンクが成立しません。

当然, 10GBase-LR と 10GBase-ER という組み合わせにして

フレーム形状を合わせても通信に用いる光の波長が異なるので、 こちらもリンクが成立しません. 10Gigabit Ethernet のインタ ーフェースは、1文字でも違うものであれば、通信はできない と思ってよいでしょう.

#### • 関連技術

10GBase-SR/SW は短波長の光を用いるインターフェースですが、使用するケーブルはおもにマルチモード光ファイバケーブル(以降 MMF)となっています。高速伝送における MMF の問題点に、信号の速度や距離(ケーブル長)の増加によりモード間の到着時間差が大きくなり通信ができなくなるというものがあります。

これはケーブルによって異なり、その特性を「モーダルバンド幅」というパラメータで示しています。この値が大きい MMF ほど、高速信号の長距離が可能であるということなのですが、一般に利用される MMF のモーダルバンド幅は、よいもので 500 程度であり、10Gbps の速度では 100m の伝送さえできません。

光ファイバケーブルで 100m の伝送さえできないというのであれば、お世辞にもあまり魅力のあるインターフェースであるとはいえないものです。しかし、長波長を用いるインターフェースは短波長に比べ高価であるため、安価(あくまで長波長のインターフェースと比較して)な短波長のインターフェースを用いて、それなりの配線を確保するために、現在ではモーダルバンド幅 2000 という MMF も市場に登場しています。

昨年 (2002年)5月,アメリカ合衆国 Las Vegas において開催された Networld+Interop 2002 Las Vegas の隠れた目玉として,マニア受けしていました.ちなみにその直後の 6月に Atlanta で開催された SuperComm 2002 Atlanta では,これはあまり展示がなく,逆にシングルモード光ファイバケーブルにおいて,1400nm 帯に発生する減衰をなくすように加工している,DWDM を意識したものが出展されていました.

#### まとめ

今回ふれていない 1000Base-CX と 1000Base-T のその後ですが、1000Base-CX は 10GBase-CX4 として、IEEE802.3akで、ツイストペアの 1000Base-T もワークグループは未定ですが、10GBase-T として(正気か?!)検討されています。

#### 参考文献

1) 松本信幸,『ギガビット・イーサネット絵とき基本用語』, (株)オーム社

まつもと・のぶゆき



第4回

# ハリウッドの法則

# フレームワーク

最近よく耳にする言葉の一つに、フレームワーク(framework)があります。日本語に翻訳すれば「枠組み」ですが、使われている文脈を読むかぎりでは、どうも枠組みとは違うようです。たとえば、

- これからの Windows プログラムは.NET Framework を使ったものが主流になるらしい
- Mac OS X プログラムでは Toolbox ではなく Framework が API になるらしい

と語られた場合、「Framework」は「枠組み」を意味しません。 その正体は、本連載でよく取り上げるGoF本 $^{\pm 1}$ で解説されています。すなわち、

●ある特定のソフトウェアを対象にした再利用可能な設計プロ ダクトを構成するクラスの集合(GoF本の「概論」p.38を参照 のこと)

ということです. ようするに, 従来は"ライブラリ"と称していたもののオブジェクト指向バージョンではないのかと思った読者もいるでしょう. 当たっている部分はありますが, そうでない部分もあります.

# 逆転した立場

というのも, ライブラリを使うのとフレームワークを使うの では決定的に異なる側面があります. あるサービスを実現しよ うと考えた場合,

- ライブラリー— サービスを実現する手続き/関数がないかを探し、見つかればそれらを"呼び出す"よう実装する
- ●フレームワークーーサービスを実現する手順を探し、見つかればフレームワークから"呼び出される"よう実装する

と、まるで立場が変わったような実装を要求されることがある からです。 たとえば、ドキュメント(文書)を保存する例で考えましょう。ライブラリを使う場合、ドキュメントを保存するときは、

- 1) ドキュメントの名前でファイルを作成する手続きを呼び出す
- 2) ファイルにドキュメントの内容を書き込む
- 3) ファイルを閉じる手続きを呼び出す というのが典型パターンでしょう. UNIX, あるいは UNIX 系 のライブラリを使うなら,
- fopen
- fwrite
- 3) fclose

あたりを利用するでしょう。ところが、文書つきアプリケーションフレームワークを利用する場合は、そう単純ではありません。ドキュメントの内容管理と同時にドキュメントの表示もからみます。ドキュメントを表示するウィンドウの管理もからむので、「独断」でドキュメントの内容を保存できません。保存メニュー、復元メニューなどの許可/不許可の実装<sup>注2</sup>など、とにかく文書つきアプリケーションとしての挙動を首尾一貫させるための"約束ごと"や"世界観"にしばられるわけです。

反面,いったん約束ごとや世界観がわかれば、それらにしたがうのは案外楽なうえに、首尾一貫していることから、さほど 苫痛を感じなくなります。しかし、そこに至るまでが苫痛をともないます。プログラマによっては「耐え難い激痛」となり、フレームワークのプログラムについていけず脱落する人もいるようです。

文書つきアプリケーションの約束ごとでは、ドキュメントに関してはドキュメントクラスがあり、独自のドキュメント処理は、ドキュメントクラスを継承した独自のクラスを作成するものが多いようです。ドキュメントの保存は、保存メソッドをオーバライドすることで実装します。つまり「サービスを実現する手順を探し、見つかればフレームワークから"呼び出される"よう実装」とは、

サービスを実現する手順:ドキュメントクラスを継承し、保存メソッドをオーバライドする

注1:『オブジェクト指向における再利用のためのデザインパターン』改訂版、ソフトバンク、ISBN4-7973-1112-6.

注2:たとえばドキュメントの保存前に保存メニューを許可していたなら、保存直後は保存メニューを有効にする意味がないので不許可にする処置など.

●フレームワークから呼び出される:保存メソッドがフレーム ワークから呼び出される

を意味するわけです。ライブラリを呼び出すのとは違い、自分が呼び出される立場に逆転したわけです(**図1**)。クラスライブラリやフレームワークを使ったプログラムが苦手な人たちを観察すると、このような"立場の逆転"にうまく適応できていないように思えてなりません。

# ハリウッドの法則

このような、自分が主ではなく従になった状況を表現する用語として"ハリウッドの法則"<sup>注3</sup>があります。これは、映画の都として有名なハリウッドでは脚本や役者が採用されるかどうかはプロデューサに権限があり、脚本家や役者にはないことから来ています。おまけに、採用されたかどうかを脚本家や役者からプロデューサに問い合わせることが許されず、プロデューサから連絡が来るのをひたすら待たねばなりません。

プログラムにおいて、この状況はいうまでもなく、脚本家や役者はプログラマに相当し、プロデューサはクラスライブラリやフレームワークに相当します。プログラムをどう実装するかの主体がプログラマにはなくクラスライブラリやフレームワー

#### 〔図1〕立場の逆転



自分のプログラムはライブラリにある関数を呼ぶだけであり、 自分のプログラムが主、ライブラリが従の関係になる

(a) ライブラリの場合



自分のプログラムはフレームワークを呼ぶだけでなく,逆に呼び出されることがある.またフレームワーク特有の約束ごとや世界観にしばられてしまい,フレームワークが主,自分のプログラムが従の関係になる

(**b**) フレームワークの場合

クにあり、プログラマはひたすらクラスライブラリやフレーム ワークの約束ごとや世界観にしたがわねばならないのです。これは、従来のプログラムスタイルに慣れたプログラマをとまど わせ、プログラミングの効率が著しく落ち、それまでの自分の キャリアを否定されたかのように感じ、気分を害するプログラ マもいます。

# コールバックと継承,委譲

さきほどの「XXXクラスを継承しYYYメソッドをオーバライドする」という実装方法ですが、フレームワークやクラスライブラリ全般でわりあいよく見かけるパターンです。もちろんフレームワークによっては、継承ではなく委譲を使って実装する例もあります。

いずれにせよ従来の手続き指向ライブラリだと、おそらくコールバック関数を利用して実装することになるでしょう。そう考えると、継承とか委譲とか何やら難しげな用語で説明しなくてもいいのにと思いたいところですが、決定的に違うのは、コールバックは一つの手続き/関数の補足を利用者にやってもらうというオマケ的な意味合いが強いのに対し、継承や委譲では、処理を補足してもらうことが中心になります。補足してもらわねば何もできないという感じです。

# コールバックによる実装

一つの例として、ファイルの内容を圧縮してどこかに転送し、転送先で展開するクラスがあったとします。ファイルの読み書きや転送処理はクラスの内部で行うとして、圧縮/展開に関してはクラスの外部で実装してもらいたいとしましょう。圧縮や展開をコールバックでやってもらうという実装例をC++で示すと、UZF1のようになります $\pm 4$ .

TransferClass を利用する例はリスト2のようになります.

# 委譲による実装

委譲とは、自分が実装していない処理を誰かにやってもらうしくみのことをいいます。プログラミング言語の仕様として委譲が規定されている場合もありますが、ライブラリやフレームワークで実装する例が多いでしょう。さきほどのTransfer Class に委譲処理クラスを加えて実装しなおし、改名するとリスト3のようになります。

ここで委譲の対象となるのは、圧縮/展開処理オブジェクト (CompExpBase)です。CompExpBase は圧縮メソッド/展開メ

注3: Hollywood s law. "ハリウッドの原則"と訳している文献もある.

注4: ふだんなら Java で説明するところだが、Java ではコールバック関数が表現できないので C++ で実装した。なお検証にあたって、筆者が最近利用するようになった Mac OS X Ver.10.2.4で Project Builder を利用した。これは gcc version 3.1 ベースでコンパイルを行う。



#### 〔リスト1〕コールバックによる実装例

```
class TransferClass {
                                                                            //iCompressF=圧縮のコールバック関数
                              //アクセス対象のファイル名
    std::string mFileName;
                                                                            //戻り値は true なら成功, false なら失敗
    std::string mChannelName; //転送対象のアドレス名
                                                                            bool sendData(CompressFunc iCompressF) {
                                                                                void *aFromBuff; //圧縮前のデータの格納場所
void *aToBuff; //圧縮後のデータの格納場所
public:
    //圧縮のコールバック関数の型
                                                                                int aFromToSize; //圧縮前/後のデータの格納サイズ
    //bool compressF(const void *iData, void *oData, int& ioSize);
                                                                                //...(略)...
//送り出すデータを圧縮する
    //となる関数を想定する.この関数の引数は
    //iData=圧縮前のデータが格納されている場所
    //IData= 圧縮目のアータの恰例されている場所
//oData= 圧縮したデータを格約すべき場所
//ioSize= 圧縮前のデータのサイズ,圧縮後はここに圧縮ずみサイズを書き込むこと
                                                                                if(!iCompressF(aFromBuff,aToBuff,aFromToSize)){
                                                                                    return false:
    //戻り値は true なら成功, false なら失敗
    typedef bool (*CompressFunc)(const void *, void *, int&);
                                                                                //...(略)...
                                                                                return true;
    //展開のコールバック関数の型
    //bool expandF(const void *iData, void *oData, int iSize);
    //となる関数を想定する.この関数の引数は
                                                                            //圧縮データを受け取りファイルに展開して書き込む
//iExpandF=展開のコールバック関数
    //iData=展開前のデータが格納されている場所
    //oData=展開したデータを格納すべき場所
                                                                            //戻り値は true なら成功, false なら失敗
    //iSize=展開前のデータのサイズ
                                                                            bool recvData(ExpandFunc iExpandF) {
                                                                                void *aFromBuff; //展開前のデータの格納場所
void *aToBuff; //展開後のデータの格納場所
    //戻り値は true なら成功, false なら失敗
    typedef bool (*ExpandFunc)(const void *,void *,int);
                                                                                                //展開前のデータの格納サイズ
                                                                                int aFromSize;
                                                                                //...(略)...
//受け取ったデータを展開する
    TransferClass() {
        //...(略)...
                                                                                if(!iExpandF(aFromBuff,aToBuff,aFromSize)){
                                                                                   return false;
    virtual ~TransferClass(){
       //...(略)...
                                                                                //...(略)...
                                                                                return true;
    //転送の準備をする
    //iFileName=アクセス対象のファイル名,iChannelName=転送対象のアドレス名
                                                                            const std::string& getFileName() const {
                                                                               return mFileName;
    //戻り値は true なら成功, false なら失敗
    bool setUp(std::string& iFileName,std::string& iChannelName) {
       mFileName = iFileName;
                                                                           const std::string& getChannelName() const {
       mChannelName = iChannelName;
        //...(略)...
                                                                               return mChannelName:
        return true;
                                                                        };
    ,
//ファイルを圧縮して送り出す
```

#### 〔リスト 2〕 TransferClass を利用する例

```
static bool compressFunc(const void *iData, void *oData, int& ioSize)
    //...(略).
    return true;
static bool expandFunc(const void *iData, void *oData, int iSize)
    //...(略)..
    return true;
static void Test()
    TransferClass aTC;
    std::string aSendFile("./sendtest.bin");
std::string aRecvFile("./recvtest.bin");
    std::string aChannel("192.168.1.2");
    if(aTC.setUp(aSendFile,aChannel)){
        if (aTC.sendData(compressFunc)) {
            std::cout << "file:" << aTC.getFileName() << " was send to " << aTC.getChannelName() << ".\n";
        }else{
            std::cout << "error:send sendData¥n";
    }else{
        std::cout << "error:send setUp\n";</pre>
    //受け取る例
    if(aTC.setUp(aRecvFile,aChannel)){
        if (aTC.recvData(expandFunc))
            std::cout << "file:" << aTC.getFileName() << " was received from " << aTC.getChannelName() << ".\%";
        }else{
             std::cout << "error:receive recvData¥n":
    }else{
        std::cout << "error:receive setUp\n";</pre>
```

#### 〔リスト3〕委譲による実装例

```
class CompExpBase { //委譲オブジェクトのベースクラス(抽象クラス)
                                                                       mChannelName = iChannelName;
                                                                       //...(略)..
public:
   //圧縮のメソッド
                                                                       return true:
    //iData= 圧縮前のデータが格納されている場所
                                                                   1
   //oData=圧縮したデータを格納すべき場所
   //ioSize=圧縮前のデータのサイズ,圧縮後はここに圧縮ずみサイズを書き込むこと
                                                                   //ファイルを圧縮して送り出す
                                                                   //iCompressF=圧縮のコールバック関数
   //戻り値は true なら成功, false なら失敗
                                                                   //戻り値は true なら成功, false なら失敗
   virtual bool compressMethod(const void *iData.void *oData.
                                           int& ioSize) = 0;
                                                                   bool sendData() {
                                                                       void *aFromBuff; //圧縮前のデータの格納場所
   //展開のメソッド
                                                                       void *aToBuff; //圧縮後のデータの格納場所
   //iData=展開前のデータが格納されている場所
                                                                       int aFromToSize; //圧縮前/後のデータの格納サイズ
   //oData=展開したデータを格納すべき場所
    //iSize=展開前のデータのサイズ
                                                                       //送り出すデータを圧縮する
   //戻り値は true なら成功, false なら失敗
                                                                       if(!mDelegate->compressMethod(aFromBuff,aToBuff,
   virtual bool expandMethod(const void *iData, void *oData,
                                                                                                        aFromToSize)){
                                                                          return false;
                                             int iSize) = 0;
};
                                                                       //...(略)...
class TransDeleClass {
                                                                       return true;
   std::string mFileName;
                           //アクセス対象のファイル名
   std::string mChannelName; //転送対象のアドレス名
                          //処理を委譲するオブジェクト
                                                                   //圧縮データを受け取りファイルに展開して書き込む
   CompExpBase *mDelegate;
                                                                   //iExpandF= 展開のコールバック関数
   TransDeleClass(); //(空っぽ,パラメータなしのコンストラクタ起動防止用)
                                                                   //戻り値は true なら成功、false なら失敗
public:
                                                                   bool recvData() {
                                                                       void *aFromBuff; //展開前のデータの格納場所
   TransDeleClass(CompExpBase *iDelegate){
                                                                                      //展開後のデータの格納場所
                                                                       void *aToBuff;
       mDelegate = iDelegate:
                                                                                      //展開前のデータの格納サイズ
       //...(略)...
                                                                       int aFromSize;
                                                                      //...(略)...
                                                                       //受け取ったデータを展開する
   virtual ~TransDeleClass() {
                                                                       if(!mDelegate->expandMethod(aFromBuff,aToBuff,
       //...(略)...
                                                                                                          aFromSize)){
                                                                          return false;
   //転送の準備をする
                                                                       //...(略)...
    //iFileName=アクセス対象のファイル名,iChannelName= 転送対象のアドレス名
                                                                       return true;
    //戻り値は true なら成功, false なら失敗
   bool setUp(std::string& iFileName,std::string& iChannelName) {
                                                                   ...(略)...
       mFileName = iFileName;
```

ソッドのインターフェースのみを定義する抽象クラスです.したがって実際に圧縮/展開を行わせるためには,CompExpBaseを継承して具象クラスを作り,未実装になっているメソッド(compressMethod,expandMethod)を記述する必要があります.さらにそのクラスで発生したインスタンスを引き数にして,TransDeleClassインスタンスを作成します.以上の実装を行った例は、**リスト4**のようになります.

### 継承による実装

一方,フレームワークやクラスライブラリで見かける実装 だと,

- ●提供側:圧縮/展開メソッドを未実装にしたファイル圧縮/展 開転送クラス(抽象クラス)を用意する
- ●利用側:ファイル圧縮/展開転送クラスを使いたいなら、このクラスを継承し未実装メソッドを実装する

という役割分担になります。この考えで最初のTransferClassを実装しなおし、改名すると**リスト5**のようになります。

見てわかるとおり、圧縮/展開メソッド(compressF, expandF)が純粋仮想関数すなわち未実装になっています。このままではTransferBase は使えないので、これを継承した

クラスを作成して対応した例はリスト6のようになります.

見方によっては、コールバック関数だった箇所を純粋仮想関数に書き換えただけ、あるいは委譲クラスとして分離していたものを一つのクラスに一体化しただけです。しかし未実装箇所が一つのクラスにまとまったこと、クラスやインスタンスの数が減ることで多少見通しがよくなる効果が期待できます。

# Template Method パターン

ここで例題として出した CompExpBase, TransferBase のような「未実装メソッドがある抽象クラスを提供し、利用する側はそのクラスを継承して未実装メソッドをオーバライドして利用する」パターンを、GoF本では Template Method パターンとして紹介しています(図2).

GoF本では、Template Methodパターンを次のように説明 しています<sup>注 5</sup>.

一つのオペレーションにアルゴリズムのスケルトンを定義しておき、その中のいくつかのステップについては、サブクラスでの定義にまかせる.

注 5: GoF 本の Template Method の「目的」より引用. p.347.



#### 〔リスト 4〕 TransDeleClass を利用する例

```
class MyCompExp : public CompExpBase { //委譲オブジェクトのクラス(具象クラス)
public:
    bool compressMethod(const void *iData,void *oData,int& ioSize)
        // ... (略).
        return true;
    bool expandMethod(const void *iData, void *oData, int iSize)
        // (略)
        return true:
};
static void Test()
    MyCompExp aDelegate; //委譲オブジェクト
    TransDeleClass aTC(&aDelegate);
    std::string aSendFile("./sendtest.bin");
std::string aRecvFile("./recvtest.bin");
    std::string aChannel("192.168.1.2");
    //送り出す例
    if (aTC.setUp (aSendFile, aChannel)) {
        if(aTC.sendData()){
    std::cout << "file:" << aTC.getFileName() << " was send to " << aTC.getChannelName() << ".\n";
        }else{
            std::cout << "error:send sendData¥n";
    }else{
        std::cout << "error:send setUp\n";
    //受け取る例.
    if(aTC.setUp(aRecvFile,aChannel)){
        if(aTC.recvData()){
            std::cout << "file:" << aTC.getFileName() << " was received from " << aTC.getChannelName() << ".\n";
        }else{
            std::cout << "error:receive recvData¥n";
    }else{
        std::cout << "error:receive setUp¥n";
```

#### 〔リスト5〕継承による実装例

```
class TransferBase { //ファイル圧縮/展開転送のベースクラス(抽象クラス)
                                                                             return true;
   std::string mFileName;
                          //アクセス対象のファイル名
   std::string mChannelName; //転送対象のアドレス名
                                                                          //ファイルを圧縮して送り出す
protected:
   //圧縮のメソッド
                                                                          //戻り値は true なら成功, false なら失敗
   //iData=圧縮前のデータが格納されている場所
                                                                          bool sendData(){
   //oData=圧縮したデータを格納すべき場所
                                                                             void *aFromBuff; //圧縮前のデータの格納場所
                                                                             void *aToBuff; //圧縮後のデータの格納場所
   //ioSize=圧縮前のデータのサイズ,圧縮後はここに圧縮ずみサイズを書き込むこと
                                                                             int aFromToSize; //圧縮前/後のデータの格納サイズ
   //戻り値は true なら成功, false なら失敗
                                                                             //...(略)...
//送り出すデータを圧縮する
   virtual bool compressF(const void *iData,void *oData,int& ioSize) = 0;
   //展開のメソッド
                                                                             if(!compressF(aFromBuff,aToBuff,aFromToSize)){
   //iData=展開前のデータが格納されている場所
                                                                                 return false;
   //oData=展開したデータを格納すべき場所
    //...(略)...
   //戻り値は true なら成功, false なら失敗
                                                                             return true;
   virtual bool expandF(const void *iData, void *oData, int iSize) = 0;
                                                                          //圧縮データを受け取りファイルに展開して書き込む
public:
   TransferBase(){
                                                                          //戻り値は true なら成功, false なら失敗
                                                                          bool recvData(){
       //...(略)...
                                                                             void *aFromBuff; //展開前のデータの格納場所
                                                                             void *aToBuff; //展開後のデータの格納場所
int aFromSize; //展開前のデータの格納サイズ
   virtual ~TransferBase(){
                                                                             int aFromSize;
      //...(略)...
                                                                             //...(略)...
//受け取ったデータを展開する
                                                                             if(!expandF(aFromBuff,aToBuff,aFromSize)){
   //転送の準備をする
                                                                                return false;
   //iFileName=アクセス対象のファイル名,iChannelName=転送対象のアドレス名
   //戻り値は true なら成功, false なら失敗
                                                                             //...(略)...
   bool setUp(std::string& iFileName,std::string& iChannelName) {
                                                                             return true;
       mFileName = iFileName:
                                                                          }
                                                                          ...(略)...
       mChannelName = iChannelName;
       //...(略)...
```

#### [リスト6] TransferBase を利用する例

```
class MyTransfer : public TransferBase {
                                                                        if (aTC.setUp(aSendFile,aChannel)) {
                                                                            if(aTC.sendData()){
//ファイル圧縮/展開転送のクラス(具象クラス)
                                                                                std::cout << "file:" << aTC.getFileName()</pre>
protected:
    bool compressF(const void *iData, void *oData, int& ioSize)
                                                                                 << " was send to " << aTC.getChannelName() << ".\n";
                                                                            }else{
        //...(略)...
                                                                                std::cout << "error:send sendData¥n":
        return true:
                                                                        }else{
                                                                            std::cout << "error:send setUp¥n";
   bool expandF(const void *iData.void *oData.int iSize)
                                                                        //受け取る例。
        //...(略)...
                                                                        if (aTC.setUp(aRecvFile,aChannel)){
        return true:
                                                                            if(aTC.recvData()){
                                                                               std::cout << "file:" << aTC.getFileName()
}:
                                                                           << " was received from " << aTC.getChannelName() << ".\n";
                                                                            }else{
static void Test()
                                                                                std::cout << "error:receive recvData¥n";
    MyTransfer aTC;
    std::string aSendFile("./sendtest.bin");
                                                                        }else{
    std::string aRecvFile("./recvtest.bin");
                                                                            std::cout << "error:receive setUp¥n";
    std::string aChannel("192.168.1.2");
                                                                    }
    //送り出す例
```

#### 〔図 2〕 Template Method パターン



残念ながらこの説明は難解で、誤解を生みやすくなっています。恥ずかしながら筆者も、この説明がさっぱり理解できなかった一人です。じつは要点は"サブクラスでの定義にまかせる"にあります。表現を変えると、"提供するベースクラスでは詳細に定義しない"ともいえます。GoF本の Template Method パターンの「適用可能性」を読めば、もう少しはっきりしてきます<sup>注6</sup>.

アルゴリズムの不変な部分をまず実装し、ふるまいが変 わり得る部分の実装はサブクラスに残しておく.

例題のTransferBaseで説明しましょう.「アルゴリズムの不変な部分をまず実装」というのはsetUp, sendData, recvDataを示しています.「ふるまいが変わり得る部分」とは、純粋仮想関数である compressF, expandFです.

ふるまいが変わり得る圧縮/展開をベースクラスで実装しなかったことにより、いろいろな圧縮/展開アルゴリズムが採用できるというメリットがあります。圧縮/展開はいろいろなアルゴリズムがあり、圧縮率は良いが処理速度が遅いものもあれば、圧縮率は悪いが処理速度が速いものもあり、状況に応じて

使い分けたい場合があります。また、せっかく良いアルゴリズムであっても特許が取得されているために使えなくなるケースもあります。こういった状況があるため、アルゴリズムが簡単に変更できるとありがたいわけです<sup>注7</sup>.

# (Template Method の応用パターン

GoF本では23のデザインパターンが紹介されていますが、面白いことにほかのデザインパターンを観察すると、Template Method に通じるクラスが出現するパターンがあります。つまり「未実装メソッドがある抽象クラス」と「そのメソッドを実装した子クラス(具象クラス)」が登場するパターンです。次がそのパターンです。

Abstract Factory, Builder, Factory Method, Prototype, Bridge, Composite, Decorator, Flyweight, Proxy, Chain of Responsibility, Command, Interpreter, Iterator, Mediator, Observer, State, Strategy, Visitor

驚いたことに、かなりのパターンに見当たります. ひょっとすると「未実装メソッドがある抽象クラス」、「メソッドを実装した子クラス」の組み合わせは、オブジェクト指向プログラムでは基本的な戦術なのかもしれません.

じつは、この推測を裏づけるような"原則(Principle)"があるのですが、あまり知られていません、次回は、この原則について取り上げたいと思います。

みやさか・でんと miyadent@anet.ne.jp

注6: GoF本の Template Method の「適用可能性」より引用、p.348.

注7:アルゴリズムの変更が主体である場合は,Template Method パターンよりも Strategy パターンが見出しやすくなる.

# 指位表表用6H2E

#### 第2回

#### XScale プロセッサのプログラミング

山本繁寿

前回は、CQ RISC評価キット/XScale に搭載されている PXA250 のハードウェアと、本評価キットのメモリマップなどについて解説した。2回目の今回は、この上で動作する XScale 用サンプルプログラムについて解説する。まずは CPU ボード上の 7 セグメント LED を点灯制御するもっとも簡単なプログラムを、そしてタイマ割り込みまたはプッシュスイッチによる外部割り込み制御プログラムを解説する。最後に、UART制御プログラムや、SDRAM のテストプログラムなども解説する。 (編集部)

#### はじめに

CQ RISC評価キット/XScale に搭載されている PXA250 には、さまざまな周辺機能が内蔵されています。そのすべてを解説することはできませんが、ここでは次のようなもっとも基本的なサンプルについて、いくつか解説していきます。

- (1) LED 点灯制御プログラム
- (2) タイマ割り込みプログラム
- (3) プッシュスイッチによる外部割り込みのプログラム
- (4) シリアル通信プログラム
- (5) RAM テストプログラム
- (6) CPUモード&キャッシュ設定プログラム

# 1 LED 点灯制御プログラム

評価ボードには、赤色および緑色の LED と、7セグメント LED がそれぞれ実装されています。ここでは、各 LED を点灯 させるプログラムについて解説します。

● CqREEK/XScale CPU ボードの仕様

前回のハードウェア編で解説したように、本 CPUボード搭載の LED1(赤) と LED2(緑) および  $_7$  セグメント LED は、CS2 の空間にマッピングしたポート機能で制御します。アドレス定義のヘッダファイルを**リスト1**(a)に示します。

● LED1 および LED2 の点灯制御

これらの LED の点灯制御レジスタは、コンフィグレーションポート (アドレス 0x0A000000) にマッピングされています。 LED1 を点灯させる場合は、コンフィグレーションポートのビット 12 を 0、逆に消灯させる場合はビット 12 に 1 を書き込みます。 LED2 を点灯制御する場合は、ビット 13 に対して 0 または 1 を書き込みます。

**リスト1(b)**の **@** と **b** は、変数 led\_count のビット o とビット 1 の状態によって、LED1 と LED2 を点灯制御している例です。

7セグメント LED

7セグメント LED は、7セグメント LED ポート (アドレス 0x0A000010) にマッピングされています。7セグメント LED の各セグメント (ビット) に0を書き込むと点灯、1を書き込む

#### と消灯します.

サンプルプログラムでは、定数を配列で定義し、'o'~'F'までの 16 進数の点灯パターンを定義しています [ リスト 1 (b) の

#### 〔リスト1〕LED 点灯制御プログラム

```
#ifndef _SAMPLE_H_
#define _SAMPLE_H_
#define _ulong unsigned long
~ 中略 ~

/* CqREEK/XScale CPUボード ボート制御レジスタ */
#define CONFIG (volatile ulong *)0x0a000000
#define LEDPORT (volatile ulong *)0x0a000010
#define DIPSWIN (volatile ulong *)0x0a000018
#endif
```

#### (a) sample.h

```
#include "sample.h"
/* 7セグメント LED 点灯パターン('O' to 'F' & ' ') */
char
       led 7seg[]={0xc0,0xF9,0xa4,0xb0,0x99,0x92,0x82,
        0xd8,0x80,0x90,0x88,0x83,0xc6,0xa1,0x86,0x8e,0xFF};
                                ©7セグメント LED 点灯パター:
   int i,led count;
   /* LED カウントクリア &LED 表示クリア */
   led_count=0;
   *LEDPORT = led_7seg[led_count];
                               /* LED1/2消灯 */
   *CONFIG |= 0x3000;
   while(1){
        for(i=0;i<0x40000;i++){}/* ウェイト */
                               /* LEDカウント+1 */
        led count++;
        if (led count>15) led_count=0;
        if (led count&1) {
                              /* ピット0='1' */
            *CONFIG &= 0xefff; /* LED1点灯 */
                                                   aLED1の
                               /* ピット0='0' */
         else {
                                                   点灯制御
            *CONFIG |= 0x1000; /* LED1 消灯 */
        if (led_count&2) {
                               /* ピット1='1' */
            *CONFIG &= 0xdfff; /* LED2点灯 */
                                                   (b)LED2 O
                               /* L"y 1=101 */
         else {
            *CONFIG |= 0x2000; /* LED2 消灯 */
                                                   点灯制御
        /* LED 点灯制御 */
                                           d7セグメント
        *LEDPORT = led_7seg[led_count]; -
                                           LED2の点灯制御
int atexit()
   for(;;){}
```

(**b**) led.c

⑥〕、そして変数  $led_count$  の値によって、7セグメント LED に表示する点灯パターンを、7セグメント LED ポートに書き込みます (**リスト 1**( $\mathbf{b}$ ) の (**の**).

なお、**リスト1(b)**の最後に atexit()という関数がありますが、これは C プログラムの main() 関数の実行が終了した後に実行する処理を記述します。しかし本評価キットの環境には main() 関数が戻るべき場所、つまり OS などは用意していないので、main() 関数は必ず無限ループするように記述してください。また atexit()を記述しないとリンク時にエラーが出るので、ダミーの関数を記述しておいてください。

ちなみに、リンク時のリンクアドレスなどの指定やスタート アップルーチンは、評価キット添付のサンプルプログラムのも のを流用しています。

● ディップスイッチの状態入力

評価ボード上には8ビットのディップスイッチがあり、そのうち6ビットをユーザーが自由に使うことができます.

**リスト1**のプログラムでは使用していませんが、ディップスイッチの状態を取得する場合は、次のようにします.

c = \*DIPSWIN;

### 2

#### タイマ割り込みプログラム

ここでは、リアルタイムクロック(以下 RTC)を利用して、一定時間が経過したらタイマ割り込みを発生させ、7セグメント LEDをカウントアップ表示するプログラムについて解説します。プログラム全体の流れは、次のようになります。

- (1) RTC レジスタの初期化
- (2) 割り込みコントローラの初期化
- (3) 割り込みが発生したら7セグメント LED の点灯
- リアルタイムクロックレジスタの初期化 RTCレジスタの初期化は、次の手順で行います〔リスト 2(a) の (a)].

#### ▶ RTC割り込みを禁止 (RTSR)

RTC レジスタ初期化中に割り込みを発生させないようにするために、RTC Status レジスタ (RTSR、アドレス 0x40900008)のすべてのビットを0にして、割り込みを禁止します。

#### ▶コンペアカウンタの設定 (RTAR)

RTC Alarm レジスタ (RTAR, アドレス 0x40900004) に設定した値は、コンペアカウンタとして使用されます。RTAR レジスタに設定した値は、次に設定する RCNR レジスタの値と比較されます。RCNR レジスタの値と RTAR レジスタの値が同じになり、かつ RTSR レジスタの ALE ビット (RTC 割り込みイネーブルビット)がセットされていると、RTSR レジスタの AL (RTC 割り込み検出ビット)がセットされます。これにより、RTC を利用したタイマ割り込みが発生するようになります。

#### ▶ RTC カウンタ値の設定(RCNR)

RTAR レジスタで設定した値と比較するために、RTC Counter

レジスタ(RCNR, アドレス 0x40900000)を設定します.

#### ▶ RTC割り込みを許可(RTSR)

RTCによるタイマ割り込みを発生させるために、RTSRのALE(ビット 2)をセットして、割り込みを有効にします。

● 割り込みコントローラの初期化

PXA250 の割り込みコントローラの初期化は、次の三つのレジスタを初期化する必要があります  $(JA + 2(a) \cap b)$ .

- ●割り込みソースの設定(ICMR)
- ●割り込みの種類の設定(ICLR)
- IDLE モード中の割り込みの設定(ICCR) 個々のレジスタの設定について解説します.

#### ▶割り込みの種類の設定(ICLR)

PXA250 は ARM アーキテクチャの CPU です。ARM アーキテクチャには割り込みとして、IRQ 割り込み、FIQ 割り込み、Yフトウェア割り込みの3種類があります。ここでは、タイマ割り込み (RTC 割り込み)を IRQ 割り込みとして設定するために、Interrupt Controller Level レジスタ (ICLR、アドレス 0x40D00008)の IL31 (ビット31) を 0 にクリアします。

#### ▶ IDLE モード中の割り込みの設定 (ICCR)

PXA250 は IDLE モードになると CPU コアクロックは停止します. IDLE モード中にすべての有効な割り込みを CPU に入れるためには、Interrupt Controller Control レジスタ (ICCR、アドレス 0x40D00014)の DIM (ビット o)を o にクリアします.

#### ▶割り込みソースの設定(ICMR)

PXA250の割り込みには、シリアルや USB などの CPU 内蔵デバイスによる割り込み、外部に接続したデバイスから GPIO を使って割り込みを入力する外部割り込みなど、合計 22 種類の割り込み要因があります。ここではタイマ割り込みを使うので、割り込み要因としてリアルタイムクロック (RTC) を使用するために、Interrupt Controller Mask レジスタ (ICMR、アドレス 0x40D000004)の IM31(ビット31)を1にセットします。

#### ● 割り込みハンドラ

ARM アーキテクチャの本来の割り込みベクタは、0x0番地から始まります。しかし評価ボードではこのアドレスにはフラッシュメモリを実装しています。ROM は書き換えることができないので、このままでは、ユーザーが自由に割り込み処理プログラムを書くことができません。

そこで評価ボードでは、RAM上に代替割り込みベクタを用意し、本来の割り込みベクタから代替割り込みベクタにジャンプするようにしています。よってユーザーが割り込み処理を記述する場合は、代替割り込みベクタを使います。評価ボードに付属したモニタデバッガを使用する場合、代替割り込みベクタは 0xA0000000 からのアドレスに配置しています。

**リスト 2(b)** に代替割り込みベクタや割り込みハンドラのソースを示します。割り込みハンドラでは、スタックやコンテキストなどの保存、CPUモードの設定、多重割り込みへの対応など、割り込み処理の前処理を行います。

# X与引起 可证证 彻底活用研究

#### 〔リスト2〕RTCによるタイマ割り込みプログラム

```
volatile int timer count;
~ 中略 ~
int main(void)
   int i,led_count;
   /* PTC 初期化 */
                      /* intrrupt disable */
   *RTSR = 0x0001;
                      /* compare count set */
                                                  @RTC の
   *RTAR = 0 \times 0.002:
                      /* count 0 clear */
                                                  初期化
   *RCNR = 0x00000:
   *RTSR = 0 \times 00004:
                      /* intrrupt enable */
   /* 割り込みコントローラ初期化 */
   *ICLR &= 0x7FFFFFF;
                          /* RTC=IRQ */
                                                  b 割り込み
   *ICCR = 0x00000000;
                                                  コントローラ
                          /* RTC割り込み使用 */
   *ICMR |= 0x80000000;
                                                  の初期化
   /* RTC割り込みカウンタクリア */
   i=timer_count=0;
   /* LED カウントクリア &LED 表示クリア */
   led_count=0;
   *LEDPORT = led 7seg[led count];
   while(1){
        /* RTC割り込みが発生したか確認 */
        if (i!=timer_count) {
            led count++;
            if (led count>15) led count=0;
             /* LED 点灯制御 */
             *LEDPORT = led 7seg[led count];
             /* 現在のカウント値を保存 */
            i=timer count;
                        ⑥割り込みが発生したら
   }
                        フセグメント LED を
                        ,
カウントアップ表示
  以下略 ~
```

#### (a) timer.c

```
#include "sample.h"
    中略 ~

extern volatile int timer_count;
    中略 ~

void SS_Irq(void)
{
    /* RTC割り込み発生 */
    if((*ICIP & 0x80000000) == 0x80000000) {
        timer_count++;
        *RCNR = 0x0000;    /* count 0 clear */
        *RTSR = 0x0005;    /* clear AL bit */
    }

    /* 他に割り込み処理があれば記述 */
}
```

(c) exception.c

本評価キットはモニタ型デバッガなので、デバッガが起動状態にあるときは実際にはすでに CPU が稼動状態にあるわけですが、本評価キットではユーザープログラムの実行開始時、この代替割り込みベクタのリセットベクタから実行を開始するようになっているので、ここにスタートアップルーチンの記述も必要になります。つまり、リスト 2(b) は割り込み処理対応のstartup.s というわけです。

#### • 割り込み処理

RTCによるタイマ割り込みが発生すると、本来の割り込みべクタから代替割り込みベクタにジャンプし、**リスト2(b)**に示すように、SS IrqというCの関数にジャンプするようになっ



(b) startup.s

ています.

リスト 2(c) に実際の割り込み処理の内容を示します。まず ICIP レジスタを読み出し、発生した割り込みが RTC 割り込み かどうかを確認します。RTC 割り込みだった場合は、割り込みカウント変数をインクリメントし、RTC レジスタをアクセスしてカウンタと割り込み要求をクリアして戻ります。

実際にフセグメント LED を点灯制御する部分は、リスト2

#### 〔リスト3〕プッシュスイッチによる外部割り込みプログラム -

```
#include "sample.h"
volatile int gpio_count;
volatile int mode;
~ 中略 ~
int main(void)
   int i, led count;
   mode = *DIPSWIN & 0x2; /* 接続方式を検出 */
   switch (mode) {
        case 0x0: /* USB接続 */
            /* GPIO(GP1)割り込み初期化 */
             *GRER x = *GRER x & 0xFFFFFFFD;
             /* GP1 立ち下がりエッジ検出 */
             *GFER x = *GFER x | 0x00000002;
             /* GP1 入力方向 */
             *GPDR x = *GPDR x & 0xFFFFFFFD;
             *GEDR_x = 0x00000002;
            /* 割り込みコントローラ初期化 */
            /* GP1=IRQ */
            *ICLR &= 0xFFFFFDFF;
            *ICCR = 0x000000000:
            /* GP1 割り込み使用 *
             *ICMR = 0x00000200;
            break:
                                                  ② 初期化部分
        case 0x2: /* シリアル接続 */
            /* GPIO(GPO)割り込み初期化 */
             /* GPO 立ち上がりエッジ検出 */
             *GRER x = *GRER x & 0x00000001;
             *GFER_x = *GFER_x & 0xFFFFFFFE;
             /* GPO 入力方向 */
             *GPDR x = *GPDR x & 0xFFFFFFFE;
             /* GPO エッジ検出フラグクリア */
             *GEDR_x = 0x00000001;
            /* 割り込みコントローラ初期化 */
             /* GP0=IRQ */
            *ICLR &= 0xFFFFFFFF;
            *ICCR = 0x000000000:
            /* GPO 割り込み使用 */
            *ICMR |= 0x00000100;
            break.
        default:
            break:
   /* GPIO割り込みカウンタクリア */
   i=apio count=0:
   /* LED カウントクリア &LED 表示クリア */
   *LEDPORT = led_7seg[led_count];
        /* GPIO割り込みが発生したか確認 */
        if (i!=gpio_count) {
            led_count++;
            if (led_count>15) led_count=0;
             /* LED 点灯制御 */
            *LEDPORT = led_7seg[led_count];
/* 現在のカウント値を保存 */
            i=gpio_count;
   }
  以下略 ~
```

(a) gpio.c

(a)の ⑥ に示すようにメインルーチンに置いています. 保持してある変数と割り込みカウント変数を比較し, 一致しなければ割り込みが発生したことになるので, 7セグメント LED をカウ

```
#include "sample.h"
 中略
extern volatile int
                       timer count;
~ 中略 -
void
        SS_Irq(void)
   switch (mode) {
        case 0x0: /* USB接続 */
             /* GPIO(GP1)割り込み発生 */
             if((*ICIP \& 0x00000200) == 0x00000200) {
                  /* GP1 立ち下がりエッジ検出 */
                  if (*GEDR x & 0x00000002) {
                       /* 検出フラグクリア */
                       *GEDR x = 0x000000002;
                       gpio count++;
             break:
        case 0x2: /* シリアル接続 */
             /* GPIO(GP0)割り込み発生 */
             if((*ICIP & 0x00000100) == 0x00000100) {
    /* GPO 立ち上がりエッジ検出 */
                  if (*GEDR_x & 0x00000001) {
                       _
/* 検出フラグクリア */
                       *GEDR_x = 0x0000001;
                       gpio_count++;
                  }
             break:
        default:
             break;
   }
   /* 他に割り込み処理があれば記述 */
```

(b) exception.c

ントアップ表示するという内容です.

リスト2のプログラムではRTAR レジスタに2を設定しているので、約2秒に1回、7セグメント LED の表示がカウントアップします.

#### 3 プッシュスイッチによる 外部割り込みプログラム

● プッシュスイッチの仕様

次は、プッシュスイッチによる外部割り込みのプログラムについて解説します。評価ボードには、次の3種類のプッシュスイッチが実装されています。

- RESET スイッチ ...... リセット入力
- BRKRQ スイッチ ... ... GP1 の入力
- GPo スイッチ...... GPo の入力

RESET スイッチを押すと CPU ボード全体にリセットがかかるため、一般的な外部割り込みの評価には適していません。そこで残るのは、BRKRQ スイッチと GPo スイッチです。

本評価ボードはデバッガとの接続にシリアル接続と USB 接続を選択できますが、CPUボードの仕様上、シリアル接続時は GP1入力を強制ブレーク機能に、USB 接続時は GP0 を USB 電源検出用に使っています。

# **松子园园园园园** 徹底活用研究

よって、JCOM2 を使わない場合は GP1 につながっている BRKRQ スイッチが、USB を使わない場合は GP0 につながっている GP0 スイッチが、ユーザーが自由に使える GP 入力スイッチとなります。

なお、ボードの仕様上、GPo スイッチを押すと"H"レベルが、BRKRQ スイッチは押すと"L"レベルが入力されます。よって 検出するエッジが逆になるので注意してください。

プログラミングの手順は、次のようになります.

#### ▶ USB 接続時

- (1) GP1 の立ち上がりエッジ検出を無効(GRERo)
- (2) GP1 の立ち下がりエッジ検出を有効 (GFERo)
- (3) GP1を入力に設定(GPDRo)
- (4) GP1のエッジ検出フラグをクリア(GEDRo)
- (5) GP1 の割り込みを IRO に設定 (ICLR)
- (6) IDLE モード中の割り込みの設定 (ICCR)
- (7) GP1 の割り込みを許可(ICMR)

#### ▶シリアル接続時

- (1) GPo の立ち上がりエッジ検出を有効(GRERo)
- (2) GPo の立ち下がりエッジ検出を無効(GFERo)
- (3) GPo を入力に設定(GPDRo)
- (4) GPoのエッジ検出フラグをクリア(GEDRo)
- (5) GPoの割り込みを IRO に設定 (ICLR)
- (6) IDLE モード中の割り込みの設定 (ICCR)
- (7) GPo の割り込みを許可(ICMR)次に、初期化の手順を説明します[リスト3(a)の @).
- GPIO の初期化

#### ▶ GP0/GP1 の立ち上がりエッジ検出 (GRER0)

シリアル接続時は、GPo の立ち上がりエッジを検出するので、GPIO Rising Edge detect Enable レジスタ o (GRERo, アドレス 0x40E00030)のビット o をセットしておきます.

USB 接続時は GP1 の立ち下がりエッジを検出するので、立ち上がりエッジを検出する GRER0 のビット 1 はクリアしておきます.

#### ▶ GP0/GP1 の立ち下がりエッジ検出 (GFER0)

USB接続時はGP1の立ち下がりエッジを検出するので、GPIO Falling Edge detect Enable レジスタ o(GFERo レジスタ, アドレス 0x40E0003C)のビット1はセットしておきます。シリアル接続時はGPoの立ち上がりエッジを検出するので、立ち下がりエッジを検出する GFERo のビット o はクリアしておきます。

#### ▶ GP0/GP1 を入力に設定 (GPDR0)

GPIO Pin Direction レジスタ o (GPDRo レジスタ, アドレス 0x40E0000C) の PDo (ビット o) または PD1 (ビット 1) を o に 設定することで、GPo/GP1 を入力に設定します.

#### ▶ GP0/GP1 のエッジ検出フラグをクリア(GEDR0)

GPIO Pin Direction レジスタ o (GEDRo レジスタ, アドレス 0x40E00048)の EDo(ビット o) または ED1(ビット 1)に 1を

書き込み、すでにエッジ検出フラグが立っていればクリアして おきます.

#### ▶ GP0/GP1 の割り込みを IRQ に設定 (ICLR)

GPo/GP1の割り込みをIRQで使うので、ICLRのビット8またはビット9をクリアします。

#### ▶ IDLE モード中の割り込みの設定(ICCR)

これは、先ほどのタイマ割り込みの例と同じです.

#### ▶ GP0/GP1 の割り込みを許可(ICMR)

GPo/GP1からの割り込みを許可するために、ICMRのビット 8またはビットgをセットします。

#### • 割り込み処理

リスト **3(b)**に実際の割り込み処理関数を示します。ICIPのビット 8 またはビット 9 をチェックして、GPo または GP1でGPIO割り込みが発生したことを判定します。GPo または GP1からの割り込みであることが確認できたら、GPo または GP1のエッジ検出フラグをクリアして割り込み要求をクリアし、割り込みカウント変数をインクリメントして処理を終わります。

実際に7セグメント LED を点灯制御する部分は、さきほどのタイマ割り込みと同じです。

GP0 および GP1 はデバッガも使っているので、各レジスタは 使用するリソース以外の設定は状態を保存するように気をつけ てください。

# 4

#### シリアル通信プログラム

次は、シリアルポートを使った通信プログラムを作成して みます。

#### FFUART と GPIO

PXA250の GPIO は、 $GP0 \sim GP80$  までの 81 本あります.このなかで  $GP34 \sim GP41$  は、Alternate Function として FFUART の機能と兼用ピンになっています.リセット直後のデフォルト設定では、GPIO として動作しています.

また評価ボードにはシリアルポートとして JCOM1 と JCOM2 の 2 ポート実装されています。 JCOM1 は CPU の FFUART に, JCOM2 は CPU の BTUART に接続されています。 JCOM2 は デバッガとの接続でシリアル接続を選択した場合に使うポート なので、ここでは JCOM1 を使います。

さて、JCOM1 つまり FFUART を使用するためには、GP34 ~ GP41 を汎用 I/O ポートではなく、FFUART として機能するように内蔵レジスタを設定します。FFUART を設定するためには、GPIO Alternate Function レジスタの  $GAFR1_L$  レジスタ (アドレス 0x40E0005C) のビット 4 からビット 19 までを、次のように設定する必要があります。

AF34 (GP34) : ビット 5/4=' 01 ' AF35 (GP35) : ビット 7/6=' 01 '

AF36 (GP36) : ビット 9/8=' 01 '

AF37(GP37): ビット 11/10=' 01'

AF38(GP38):ビット13/12='01'

AF39 (GP39) : ビット 15/14=' 10'

AF40 (GP40): ビット 17/16=' 10'

AF41 (GP41) : ビット 19/18= 10 '

さらに、FFUART のうち、TXD と DTR、RTS の各ピンを、 出力方向に設定する必要があります。TXD および DTR、RTS の各ピンを出力方向に設定するためには、GPIO Pin Direction レジスタの GPDR1 レジスタ (アドレス 0x40E00010) のビット 7(DP39) からビット 9(DP41) までのビットを 1 にセットします。

PXA250では、GPDRレジスタはGPIOのピン方向制御レジスタですが、I/O機能としての入出力方向という意味ではなく、GPIOのピンそのものの入出力方向設定なので、そのピンをFFUARTとして使う場合は、FFUARTとしての入出力方向を設定しなければならない点に注意してください。

#### • RS-232-C ドライバのイネーブル

用途によっては JCOM1 を使わずに I/O ポートを多用したい場合も考慮して、JCOM1 を使わない場合は、FFUART と JCOM1 の間の RS-232-C ドライバをディセーブルに設定できるようになっています。ここでは JCOM1 を使ったシリアル通信を行うので、この RS-232-C ドライバをイネーブルに設定しなければ、正常に通信が行えません。

RS-232-C ドライバをイネーブルに設定するには、コンフィグレーションポートのビット9を1にセットします。

#### ● FFUART 初期化

次は FFUART の初期化が必要です。初期化手順は、次のようになります。

- (1) ボーレートジェネレータの設定(FFDLL/FFDLH)
- (2) データビットおよびストップビットの設定(FFLCR)
- (3) 送信および受信 FIFO の設定 (FFFCR)
- (4) モデム制御の設定(FFMCR)
- (5) FFUART のイネーブル設定 (FFIER)

PXA250の UART は、PC/AT 互換機などで使われている 16550 と同じです。ただし、レジスタのアドレスは4バイト単位になっているので、32 ビットサイズでアクセスする場合は最下位8 ビットのみを使います。

#### ▶ボーレートジェネレータの設定 (FFDLL/FFDLH)

まず通信速度の設定が必要です. そのためには Divisor Latch Low レジスタ (FFDLL) および Divisor Latch High レジスタ (FFDLH) に値を設定します. しかし, このレジスタはすぐにはアクセスできません. Line Control レジスタ (FFLCR) のビット 7 を 1 にすることで, FFDLL レジスタと FFDLH レジスタがアクセスできるようになります.

ボーレートジェネレータに設定する値は、次の公式で表すことができます。

ボーレート値 =14.7456MHz ÷ (16 × DEVISOR)
DEVISOR は 16 ビットの値で,DEVISOR のビット 7~0 には
FFDLL レジスタの下位 8 ビットが,DEVISOR のビット 15~

8にはFFDLHレジスタの下位8ビットが入ります。

サンプルプログラムでは、通信速度を 9600bps に設定するので、

 $DEVISOR = 14.7456MHz \div 9600bps \div 16$ 

で、96となります。よって、FFDLLには96、FFDLHには0 を書き込みます。

#### ▶データビットおよびストップビットの設定(FFLCR)

データビットは Line Control レジスタ (FFLCR) の WLS(ビット 1 およびビット 0), またストップビットは同じく FFLCR レジスタの STB(ビット 2) で設定できます。ここでは、データビット長を8ビットキャラクタ、ストップビットを 1 に設定します。よって実際に設定する値は 0x3 になります。

#### ▶送信および受信 FIFO の設定 (FFFCR)

送信および受信 FIFO を有効にするために、FIFO Control レジスタ (FIFOCR) の TRFIFOE (ビット o) をセットします。

#### ▶モデム制御の設定(FFMCR)

RTS出力信号をアクティブ (Request to Send) にするために、Modem Control レジスタ (FFMCR)の RTS (ビット 1) をセットします。また、DTR出力信号をアクティブ (Data Terminal Ready) にするために、同じく FFMCR レジスタの DTR (ビット 0) をセットします。

#### ▶ FFUART のイネーブル設定 (FFIER)

UART ユニットを有効にするために、Interrupt Enable レジスタ(FFIER)の UUM(ビット6)をセットします.

#### シリアル送受信

シリアルポートからデータを受信すると、FFLSR レジスタのビット 0 が 1 になります。これをメインループで判定します。このビットに 1 が立ったら、受信データを取り出すためにReceive Buffer レジスタ (FFRBR) を読み出します。受信データは下位 8 ビットに格納されます。

エコーバックなので、受信したデータをそのまま送信します。 データを送信するには、送信バッファに空があるかどうかを確 認する必要があります。FFLSR レジスタのビット 5 が 1 なら、 送信バッファに空きがあります。送信バッファに空きがあるこ とを確認したら、送信データを Transmit Holding レジスタ (FFTHR) に書き込みます。

なお今回のプログラムは、送信バッファに空きがないと空くまで待つという処理になっていますが、実際にはその間に受信バッファがいっぱいにならないようにフロー制御なども必要です.

ここまで解説したサンプルプログラムを**リスト4**に示します. **リスト4**のプログラムは、データを受信すると7セグメント LEDをカウントアップ表示します.

#### 5 RAM テストプログラム

メモリチェックの方法は、まず、異なるアドレス範囲(範囲 長は同じでスタートアドレスのみ異なる)に対して、同じデー タを書き込み、それぞれの合計を求めます。それぞれの合計値

#### (リスト4) シリアル通信(エコーバック)プログラム

```
void FFUART init(int bps)
   int i:
   *GAFRO_y = (*GAFRO_y & 0xFFF0000F) | 0x0000A9550;/* FFUART使用 */
   *GPDR V
           = (*GPDR_y & 0xffffffC7f) | 0x00000380;/* ffUART(ffTXD,ffDTR,ffRTS出力) */
   *CONFIG |= 0x200; /* RS-232-Cドライバイネーブル */
   switch(bps){
        case 1200 :
             i=768:
             break:
        case 2400 :
             i=384;
             break:
                                                                                int main(void)
        case 4800 :
             i=192:
                                                                                    int led_count;
             break:
                                                                                    unsigned char c;
        case 9600 :
             i=96;
                                                                                     /* LED カウントクリア &LED 表示クリア */
             break;
                                                                                    led count=0;
        case 19200 :
                                                                                    *LEDPORT = led_7seg[led_count];
             i=48;
             break;
                                                                                    /* FFUART初期化 */
        case 38400 :
                                                                                    FFUART_init(9600);
             i = 24
             break:
                                                                                    while(1){
        default :
                                                                                         if (*FFLSR & 1) { /* 受信データあり */
             i=96:
                                                                                             led count++; /* LEDカウント+1 */
             break:
                                                                                              if (led count>15) led count=0:
                                                                                              *LEDPORT = led_7seg[led_count];
c=*FFRBR; /* データ読み出し */
   *FFLCR = 0x80; /* Serial Line Control reg; set Divisor reg access bit */
   *FFDLL = i;
                  /* Divesor reg; baud tate: i */
                                                                                              /* 送信バッファに空きができるまで待つ */
   *FFDLH = i>>8;
                                                                                              while((*FFLSR & 0x20)==0) {}
   *FFLCR = 0x3; /* Serial Line Control reg; stop:1, data:8bit */
                                                                                              *FFTHR=C;
                                                                                                            /* データ送信(エコーパック) */
   *FFFCR = 0x1; /* FIFO Control reg; TandR FIFO enable */
   *FFMCR = 0x3; /* Modem Control reg; RTS,DTR:1 */
                                                                                    }
   *FFIER = 0x40; /* Interrupt Enable Register; UART Unit Enable */
                                                                                   以下略 ~
```

を比較することにより、メモリチェックが行えます。

このプログラムでは、0xA0E00000 と 0xA0E00500 から 1K バイト分の範囲でデータを書き込んでいます。次に、それぞれのデータの合計を求め、比較します。合計したデータが一致しない場合は、メモリに何らかの障害が発生していると考えられるので、7セグメント LED を使ってエラーが発生したことを表示する関数を呼びます。合計データが一致すれば、正常であることを表示する関数を呼ぶというものです(リスト5)。

#### 6 CPU モード & キャッシュ設定 プログラム

#### • PXA250 の動作モード

PXA250では動作モードとして、Turbo、RUN、IDLE、SLEEPの四つのモードがあります。評価ボードのベースの入力クロックは3.6864MHzで、内部のPLLで逓倍した後、CPUコアやメモリコントローラなど各モジュールに供給されています。周辺モジュールのクロックは基本的に固定されていますが、CPUコアとメモリクロックは変更が可能で、CCCRレジスタのL、M、Nの各バラメータにより逓倍率が決定されます。

PXA250での設定可能なパラメータと計算式は、次のようになります。

メモリ周波数= $L \times 3.6864$ MHz(L: 27, 32, 36, 40, 45)

#### 〔リスト5〕RAM テストプログラム

```
void ramCheck(void)
   int
   ulong
             *memory, *memory2;
   ulong
             test_data, start, start2, length;
   ulong sum1=0;
   ulong sum2=0;
   start = SDRAM CHECKSTART;
                                 /* set value 0xa0e000000 */
   start2 = SDRAM CHECKSTART2; /* set value 0xa0e00500 */
   length = 0x100:
   memory = (ulong *)start;
   memory2 = (ulong *)start2;
   for( i=1,test_data=0; i<length; i++ ) { /* memory check */
        *memorv = test data;
        *memory2 = test_data;
        memory++;
        memory2++;
        test data++;
   memory = (ulong *)start;
   memory2 = (ulong *)start2;
   for( i=1; i<length; i++) {
                                 /* memory data sum */
        sum1 += *memory;
        sum2 += *memory2;
        memory++;
        memory2++;
   if(sum1 == sum2) { /* memory data sum compare */
        OK LED();
   } else {
        ERROR_LED();
```

#### 〔リスト6〕CPUモード/キャッシュ変更プログラム

```
ldr
                                                                                   r1,=0x1
    .qlobal
              ChangeClock
                                                                                   p14, 0, r1, c6, c0, 0
    .global
                                                                         1dmfd
              EnterTurbo
                                                                                   sp!, {r1, pc}
             _ExitTurbo
    .global
    .global
              ____EnableIcacheBtb
                                                                     ExitTurbo:
    .equ CCCR_BASE,
                       0x41300000
                                                                                   sp!, {r1, lr}
                                                                         stmfd
                                                                         /* CCLKCHG value (exit TURBO) */
_ChangeClock:
                                                                         ldr
                                                                                   r1, =0x0
             sp!, {r1, r2, lr}
   stmfd
                                                                         mer
                                                                                   p14, 0, r1, c6, c0, 0
   ldr
             r1, =CCCR BASE
                                                                         1dmfd
                                                                                   sp!, {r1, pc}
   /* CCCR value(L:x27, M:x2, N:x2) */
   ldr
             r2. = 0 \times 0.0000241
                                                                     EnableIcacheBtb:
   /* set CCCR */
                                                                                   sp!, {r1, lr}
                                                                         stmfd
                                                                         /* read CP15 Control */
             r2, [r1]
   str
                                                                                  p15. 0, r1. c1. c0. 0
                                                                         mrc
    /* CCLKCHG value (enter FCS) */
                                                                         /* set I, Z bit */
             r1,=0x2
                                                                                   r1, r1, #0x1800
   mer
             p14, 0, r1, c6, c0, 0
                                                                         /* write CP15 Control */
             sp!, {r1, r2, pc}
                                                                                  p15, 0, r1, c1, c0, 0
                                                                         ldmfd
                                                                                   sp!, {r1, pc}
EnterTurbo:
   stmfd
             sp!, {r1, lr}
                                                                         .align
                                                                                   4
   /* CCLKCHG value (enter TURBO) */
                                                                         .end
```

RUNモード周波数 =  $M \times ($ メモリ周波数)(M:1,2) Turboモード周波数 =  $N \times ($ RUNモード周波数)

(N:1, 1.5, 2, 3)

内部クロックは最大で400MHzです。リセット後のCPUのデフォルト値は、

 $L: 27 \quad M: 1 \quad N: 1$ 

となっており、メモリ周波数、RUNモード周波数、Turboモード周波数のすべてが 100MHz となります。また評価ボードではユーザープログラム実行時は、次のような設定になっています。

キャッシュ : OFF モード : RUNモード 内部クロック : 100MHz SDRAM クロック : 100MHz

モニタプログラムでM=2に変更していますが、周波数変更シーケンスは実行していないので、起動後はCPUはRUNモードで100MHzのまま動作しています。

周波数変更および RUN モードと Turbo モードの切り替えは、 コプロセッサ 14 レジスタ 6の CCLKCFG レジスタを使用しま す. レジスタのフォーマットを次に示します.

ビット1:1で周波数変更シーケンスに入る

ビット0:1で Turbo モードに入る、0で RUN モード あらかじめ CCCR レジスタに逓倍率をセットしておいてから、CCLKCFG レジスタの設定を行います。CCLKCFG の書き込みには、コプロセッサ関連用の特殊な命令を使用します。

MCR p14, 0, Rd, c6, c0, 0

● CPU モード/キャッシュ変更プログラム

リスト6に、モード/キャッシュ変更プログラムを示します。 これはアセンブラソースですが、次の関数名でC言語から呼べるように記述しています。

#### void ChangeClock (void)

クロック周波数を設定/変更します。EnterTurbo()を呼び

出す前に1度実行します. TurboモードはCPUコアを400M Hzで、RUNモードでは200MHzで動作するように設定しています.

#### ▶ void EnterTurbo (void)

ChangeClock()関数はクロック設定を変更するだけで、モードは変更しません。この関数で実際に CPUを Turbo モードに切り替えます。

#### ▶ void ExitTurbo (void)

Truboモードの状態から低消費電力動作をしたい場合は、この関数を呼び出すことでRUNモードに切り替えます。

#### void EnableIcacheBtb (void)

命令キャッシュとブランチダーゲットバッファをイネーブル に設定する関数です。

以上より、評価ボードで最高のパフォーマンスでプログラム を動かすには、

ChangeClock();

EnterTurbo();

EnableIcacheBtb();

のように、三つの関数を呼べばよいことになります. なお、データキャッシュをイネーブルにするには、XScaleの仕様上、MMUもイネーブルに設定しなければなりません.

\*

次回は、PXA250に内蔵されているUSBコントローラを使って、簡単なUSBターゲットのファームウェアと、Windows用のサンプルプログラムの作成について解説します。ご期待ください。

#### 参考文献

Intel XScale Microarchitecture for the PXA255 Processor Users
 Manual

**やまもと・しげひさ** (株)ソフィアシステムズ

# IPパケットの隙間から

# 言論の不自由とサポート環境の不自由

57

祐安重夫

今世紀に入ってからのアメリカは、本当に信じられなくなった.少なくとも建前としては残っていたはずの「自由」が、「戦争」という言葉をキーワードに、どこかへいってしまったようだ.

WIREDが伝えるところによると、OpenBSDプロジェクトの中心的なプログラマの一人であるカナダ人のセオ・テラードが、今回の「戦争」に関して、プロジェクトが DARPA から助成金を受け取っていることへの「居心地の悪さ」を表明した。この発言に対し、OpenBSDの中心的人物であるペンシルバニア大学のジョナサン・スミス教授から、不快感を伝える電子メールが届き、さらにすぐ後に DARPAからの助成金が打ち切られたことが知らされたというのである。

その後、ペンシルバニア大学には、助成金打ち切りの対象はOpenBSD全体ではなく、テラードが主催するオープンソースプロジェクトに関する集会「ハッカソン」(hackathon)のみであるという通知が届いたという。

DARPA もペンシルバニア大学も、この騒動の背景については口をつぐんでいるが、これが「反戦」の表明に対する報復であることは、誰の目にも明らかだろう。最近では「戦争」に賛成しなかった国々に対して、アメリカが報復を行うかもしれないという動きさえある。

オープンソースソフトウェアも実際の政治や経済と無関係ではいられないことは、これまで表面から論ずることがそれとなく避けられていたが、どうやらそうはいかない時代になってしまったようだ.

経済的側面についていえば、Linuxで商売をしている企業の動向についても、注目していかなければならない。

これまで筆者は、複数の Red Hat Linux 6.2 をインストールしたマシンを管理してきたのだが、Red Hat が 3 月 31 日に 6.2 へのサポートを終了してしまった。実際にセキュリティバッチをあてていれば、6.2 でも問題なく使用できていたのだが、サポートなしでは必要なバッチを自分でソースを入手し、コンパイルしてアップデートしなければならない。

ちょうど3月31日に CERT から勧告された sendmail のセキュリティホールなど、どうすればいいのかと思ったら、日本時間では4月1日だが、アメリカ時間ではまだ3月31日の間に、アメリカの Red Hat のサイトでセキュリティパッチが公開され、なんとか対応することができた。しかし、驚いたことに、アメリカ時間で4月1日になったとたん、6.2 のサポートページ自体が消滅してしまった。もっとも、その後、同じパッチが日本の Red Hat のサポートページにアップロードされたが。

そこで、複数のドメインに散らばったシステムを、まとめてアップ

グレードしなければならないことになった。その時点での最新版は 8.0 だったが、このバージョンも今年の 12月 31日でサポートが打ち 切られることが決まっている。この先、当分サポートが継続される のは、日本では4月 18日にバッケージが発売予定の(つまりその時点 ではまだ出ていない) Red Hat Linux 9.0 である。

ところで、これまで Red Hat Linux 6.2 をサポートしなければならないため、筆者自身も 6.2 の環境を使用していた。6.2 自体は安定した OS であり、サーバとして使用する分には不都合はなかったが、デスクトップ環境としてはしばらく前から、バージョンアップしないと使用できないソフトウェアがいくつかでてきていた。

それに対しては、サポート用のマシンとは別の PC を入手して、 それに新しいバージョンをインストールすればいいのだが(すでに 以前、Red Hat Linux 7.2のプロフェッショナル版を購入してあっ た)、ハードウェアの調達が滞っていた。

今回, ともかく新しい PC を調達し、そちらに 9.0 をインストール した. とりあえずサポート用の 6.2 は維持しなければならないし、 9.0 についても評価しなければならない. その 9.0 だが、サーバ環境としてのテストは現在進行中だが、とくに問題は出ていないようだ.

さて、デスクトップ環境としての9.0 はどうだろうか. 8.0 以降, GNOME がバージョン2になったのだが、その8.0 と比較しても、Nautilus が妙な具合に GNOME と一体化して、そのデスクトップを停止することができないようだ。ウィンドウマネージャは8.0 から metacity になっており、これまで sawfish を使用してきたので、機能的に不満だし、使い勝手も必ずしもいいとはいえない.

ウィンドウマネージャについては、別のものを選択する GUI がなぜかないので、

killall metacity && sawfish &

といういささか強引な方法で変更し、ログアウト時に「現在の設定を保存」することでうまくいった。しかし sawfish も GNOME2 対応のバージョンになっており、バグがかなりあるようだし、機能的にも必ずしも満足できないが、とりあえず metacity よりはましである。

サーバ環境については移行できそうだが、デスクトップ環境としてはまだまだ移行に手間がかかりそうだ.

---

すけやす・しげお インターメディアアクセス

# 組み込み **Inuxを** とりまく世界

第1回 組み込み Linux の長所短所とスマートな導入のための要素 山中 勝)

オープンソースの旗手として猛スピードでダッシュを続ける Linux は、とくにサーバの領域でシェアを伸ばしており、また、 デスクトップ分野ではオフィスソフトも充実し、機能的には既 存の OS と肩を並べる実力をもつまでになった。また、組み込 みシステムにおいてもネットワーク機器、携帯電話などへの搭 載も始まり、実用段階に入ろうとしている。

本稿では、組み込み Linux を採用する上での問題点を検証 し、効率良く導入する方法について、現実的な視点から検討す る. さまざまなテーマを隔月で6回、解説していく予定である.

#### なぜ、組み込み Linux なのか?

インターネットの普及、半導体技術の進歩により、組み込みシステムに要求される機能の増大やシステムの小型化、省電力化などに対応するため、ソフトウェアに占めるコストの増加とTime to Market に対する開発期間の短縮など、組み込みシステム開発に対する要求の急速な変化に対応することが、開発者に求められている。

この要求に応えるために注目されているのが Linux である. Linux は、エンジニアリングワークステーション (EWS) に広く 採用されていた UNIX システムと同等のものであり、組み込みシステムの開発ホストマシンとしても利用されている汎用 OSで、ネットワーク、ファイルシステムなど、今日の組み込みシステムに要求される機能を基本的に備えている.

「組み込みシステム」といわれるものは、パソコンの部品のような小さなものから、電話交換機など複数のシステムを統合して制御するものまで、広いスケールをカバーしている。組み込みシステムに搭載される CPU はパソコンのように標準化されて

#### 〔表 1〕従来の組み込みシステムにおける問題点

- ●CPU、OS、開発ツール、コンポーネントの組み合わせに制限があり、望みのシステムが構成できない
- ●OS ベンダからソースコードの提供が行われない,あるいは高額な費用が必要
- ●開発システム変更のたびにコードの修正,ツールの学習が必要
- ●フラグメント化されたシステムのため、バグフィックスのスピードが遅い

おらず、さまざまなアーキテクチャが採用されている。また OS については、リアルタイム OS (RTOS) がおもに採用されている。大容量のメモリを必要としない OS として提供されているものが RTOS であったことなどから、組み込み OS イコール RTOS という認識になってしまった。組み込み OS は、CPUのアーキテクチャ以上に非常に多くの種類が提供されている。

したがって、組み込みシステムを開発する場合は CPU、OS、開発ツールなどについて調査、検討するところから、ネットワーク、ファイルシステムなど必要なコンポーネントの検討にいたるまでの作業を必要とした。これらの選定を行う際、必要な要素の組み合わせが必ずしも要求をすべて満たすわけではなく、また性能のテストも実際に使用してみるまで行えない場合も多く、困難をきわめていた。表1に従来の組み込みシステムにおける問題点をあげる.

これらの問題を解決するものとして、オープンソースのシステムはソースコードの提供によりプログラミングの自由が保障されており、ロイヤリティの発生が抑制されている。半導体技術の進歩により高性能な CPU、大容量のメモリが低価格で提供されるようになり、組み込みシステムへの汎用 OS の搭載が現実のものとなった。また、オープンソースの発展にともない自由なプログラミング環境がもたらされたことにより、汎用システムにおけるオープンソースへの移行が、組み込みシステムにおいても主流になりつつある。オープンソースの OS としてはLinux 以外にも FreeBSD など多くのシステムがあるが、Linuxの自由で現実的な方針による進化のスピードが今日の繁栄を支えており、変化の激しい組み込みシステムにおける Linux の長所を享受できる。表2に組み込みシステムにおける Linux の長所

#### 〔表 2〕組み込みシステムにおける Linux の長所

- GPLの下でソースコードが提供されており、プログラミングの自由が保障されている
- ●開発ツールは多くの CPU をサポートしている GNU ツールで統一されている
- ●世界中のプログラマが日々システムの開発、テストを行っており、 新しい機能の導入やバグフィックスのスピードが非常に速い
- ●Linux ホスト上で開発されたソフトウェアがターゲット上で利用可能
- □イヤリティフリーである

# 組み込み linuxをとりまく世界

をあげる

今日の複雑で多様な組み込みシステムを構築する上で、ネットワークをはじめとする多くの要求を満たし、負担の増加したソフトウェア開発の効率化には Linux が非常に適しており、大小さまざまな規模のシステムにおいて採用される要因となっている。

エンジニアのひとり言:その1

GPLを悪者呼ばわりするのであれば使わなければいいのに、オープンソースはもうからないけれど強力なからくりだ。

#### 組み込み Linux 導入の問題点

組み込みシステムにおける多くのメリットをもたらす Linux ではあるが、いくつかの問題点もかかえている。組み込みシステムにおける Linux の問題点を**表3**にあげる。

オープンソースで提供されるソフトウェアはいっさいの保障が行われないため、利用者の責任において使用することとなる。実際に提供されるソフトウェアはテストの有無、コードの品質を含めバラつきがある。したがって、製品に搭載する場合は商用OSのように安定した品質でテスト済みのものが提供されないため、自前でテストを行うか専門ベンダによってテスト済みのものを利用することとなる。「オープンソースはフリーである」という意味を「タダ」と解釈している場合が多く見られるが、本来は「プログラミングの自由」が保障されているという意味なのである。

また、ソースコードは公開されているが、汎用 OS である Linux のソースコードは C 言語の教科書に記載されているよう な簡単なものではない、ビルドの際に用いられている複雑な Makefile やマクロ定義を解読するためには高いスキルを必要と する.

したがって、商用 OS のようにテスト済みのものを提供するベンダのサポートサービスを利用し、安心してアプリケーション開発に集中するのがスマートな Linux の利用方法の一つとなる。

Linux を利用する上で、ライセンスの問題が採用を躊躇させる要因となる場合がある。ご存知のように Linux は FSF (Free Software Foundation)の GNU GPLにて提供されている。GPLはプログラミングの自由を保障するため、修正を加えたカーネルなどのソースコードを公開する義務を課している。アプリケーションに関しては LGPL と呼ばれる、GPL よりゆるいライセンスによって、ダイナミックリンク形式で Linux のライブラリとリンクすることにより、実質的にソースコードの公開義務を免除している。これ以外にも C++ のライブラリのように、GPLではあるものの例外事項によりソースコードの公開が不要なものも存在する。これらの例外は、ほかのオープンソースソフト

#### 〔表3〕組み込みシステムにおける Linux の問題点

- ●オープンソースは無保証である
- •ソースコードは公開されているが、簡単に理解できるわけでは ない
- ●GPL はプログラミングの自由を保障するライセンスで、修正した内容は公開しなければならない
- リアルタイム機能がサポートされていない場合が多い

ウェアとの親和性や FSF の戦略的な要因から設けられている。 また、Linux のデバイスドライバにおける GPL の扱いについ ては、著作権者である Linus Tovalds の追記事項の解釈により、 ローダブルモジュール形式を用いればソースコードの公開は必 要ないと解釈される場合があるが、厳密な FSF の解釈にしたが って公開の義務があると解釈される場合もある。利用者の現実 的な立場から見れば、セキュリティなど公開することにより情 報の安全性などに影響を与える可能性のあるもの、商用コンポ ーネントの利用の際に、GPL とのライセンス上の矛盾が発生す るものなど、ソースコードの公開が行えないものとの協調利用 が必要なものがある。

これらのライセンスについては、法律家においても 100%共 通の解釈が行われるわけではなく、実際に訴訟が起こってみな いと解答は得られないかもしれないが、ソースコードの実装の 方法により限りなくクリアにすることも可能である.

基本的にはソースコードを公開する精神がたいせつであり、 公開することにより公に認められ、製品ベンダに対する信頼に 結びつく、実際にソースコードを公開したことによりヒットし た拡張ボードなどの事例もある。

オープンソースのライセンスに関する情報については、雑誌などの断片的な情報により GPL は危険なものという誤った解釈をされている場合も多く、正しく認識して GPL にともなうリスクを把握することにより、Linux が充分製品に利用可能であることを認識していただけるものと思う。オープンソースに関する書籍や、次に示す Web サイトの情報をぜひご一読いただきたい。

http://www.opensource.org/

Open Source Initiative (OSI)

#### エンジニアのひとり言:その2

展示会のデモプログラムをまず PC の Linux ホスト上で作成して、完成後ターゲット用のクロスツールでリビルドしたところ、何事もなかったように動作した。アプリの開発は驚くほど簡単である。一度お試しあれ、

組み込みシステムにおいて必ず問われるのがリアルタイム機能である。一般的に、割り込みやイベントに対する応答時間を最悪値として保障する「ハードリアルタイム」と、確率的に保証する「ソフトリアルタイム」に分類される(**図1**)、ハードリアル

タイムは、車両、FAシステム、原発などのように、いかなる場合でも絶対に応答時間が保証されないと災害や甚大な損害を生じるシステムに採用されている。ソフトリアルタイムは、応答時間がある確率以上で保証されていればよいシステムで利用されている。従来の組み込みシステムにコンパクトなOSとして採用されてきたRTOSだが、本当にハードリアルタイム機能が必要な場合は、組み込みシステム全体においても非常に少ない分野に限定されており、本質的に一般的なLinuxで充分対応可能となっている。

汎用システムである Linux は、システムコールなどのカーネ ル内部の処理実行中は割り込みを禁止状態にするため、割り込 みに対する応答時間にバラつきがあり、リアルタイムシステム に必要とされる割り込み応答時間の保証ができない。また、仕 事の処理単位であるプロセスに対して平等に CPU 時間を割り 当てるよう、動的に優先順位を割り当てるポリシが採用されて おり、割り込みに対応したプロセスの応答時間も保証できない。 これに対しリアルタイムシステムでは、カーネル内部の処理実 行中においても、可能なかぎり割り込みを有効にしており、割 り込み応答時間を保証している。また、仕事の処理単位である タスクやスレッドに対して静的な優先順を割り当て、イベント などに対するタスクやスレッドの応答性を確保している。しか し「リアルタイム」という名称から、リアルタイムシステムのほ うが処理速度も速いと思われている傾向がある。実際は割り込 みを受け付ける時間が長い分、割り込みによる実行中の処理の 中断によるコンテキストのスイッチが頻繁に発生し、非リアル タイムシステムに比べて、全体のパフォーマンスは割り込みの 頻度に比例して低下する.

#### エンジニアのひとり言:その3

どんなにすぐれたRTOSでも間に合わない場合がある。 そんなときは割り込みベクタから直接処理を行うことになる わけで、ちょっとしたリアルタイム機能なら、大げさなシス テムがなくても簡単に対応できる。

Linux においても、さまざまなリアルタイムシステムが提供 されている。カーネル内部の処理部分に割り込み禁止状態を 可能なかぎり取り除くコードを追加したもの、プロセスのスケジューリングをリアルタイムシステムに変更したもの、あるいはほかのリアルタイムシステムとのハイブリッドシステムなど、多彩である.

#### 組み込み Linux のスマートな導入

従来から使用している RTOS から Linux への移行は単純ではない。多くの RTOS は、タスクあるいはスレッドと呼ばれるメモリ管理などを含まない比較的シンプルなジョブコントロールで、Linux のプロセスのように仮想記憶をサポートする汎用システムとは異なる。また、ファイルシステムやネットワークシステムも標準的にサポートしており、これらの機能をオプションのコンポーネントのタスクとして実装している RTOS とは異なり、複雑なシステムである。

また、ソースコードは公開されているものの Linux のコードは複雑で、一夜にして理解するのは不可能である。したがって、短期間で Linux システムを構築するためには、Linux に精通したエンジニアを確保して自社の製品へのポーティングを行うか、専門の組み込み Linux ベンダに開発を依頼することになる。いずれにしても、人的あるいは多大な開発コストが必要となる。

さらに Linux は無保証のため、製品レベルでの使用に耐えるようにするためには、開発ツールを含め厳密なテストが必要である。自前でこれらのテスト体制を用意するのは Linux のカーネル、開発ツールなど複数のエキスパートを確保する必要がある。また、これを実現するためにはかなりの費用が必要となり、組み込み Linux ベンダが提供するサポートサービスは一見高価な感じがする。しかし、同等のことを自前で行うことを考慮すれば充分リーズナブルであり、実際の製品開発においては緊急事態にも迅速なサポートが受けられる安心を得るための費用として納得できるものである。

小規模なプロジェクトやプロジェクトの初期におけるプロトタイプを構築する場合などの限られた開発コストの下で Linux

〔図 1〕ハードリアルタイムとソフトリアルタイム -





〔写真 1〕組込み Linux 評価キット



# 組み込みしinuxをとりまく世界

#### 〔表 4〕「組込み Linux 評価キット」の概要

#### 製品内容

- CD: MontaVista Linux, LSP, GNU Tools, ブートロータ (x86を除く), ドキュメント
- 評価キット利用ガイド
- 評価キットボードガイド
- ユーザー登録用紙

サポート CPU(一部開発中)

• x86, ARM, XScale (Strong ARM), SH

を導入する方法としては、Linuxが移植されているターゲットボードを利用してスタートするのが近道である。また、トレーニングやセミナなどの教育プログラムを受講してLinuxの正しい利用方法を短期間で習得するのも有効な方法といえる。

これらの方法を状況に応じて利用することにより Linux の導入をステップバイステップで、Linux に関するノウハウを蓄積しながらスキルを高めて「Linux の達人」を養成することにより、組み込み Linux の能力を有効に引き出すことができる。

さらに実際の製品を構成する要素としては、GUIシステム、メモリカードシステムなど基本的なLinuxではサポートされていないコンポーネントの調達も必要となる。これらについては、サードベンダにより提供されている製品を有効に活用することにより、開発スピードをかせぐことが可能である。

組み込み Linux のスマートな導入方法としては、次に示すようにステップバイステップで組み込み Linux のスキルを身に付けるとともに、専門ベンダが提供するテスト済みの Linux、オプションのコンポーネントを利用することにより信頼性の高いシステムを迅速に構築することである。これによりコスト、開発スピードのバランスを取りながら効率をよく Linux をスマートに導入することが可能となる。また、製品の構成や実装方法に関する問題解決の際には、専門家によるコンサルテーションやサポートも必要となる。

#### エンジニアのひとり言:その4

Linuxのサポート費用が高いとボヤく前に、複雑なシステムや開発ツールに精通したエンジニアを探すだけでも容易ではなく、多くの要素をもつサポート体制を構築するだけでもたいへんなこと思ったら、お買い得に見えてくる。

#### 「組込み Linux 評価キット」の利用

実際にスマートな Linux の導入を行う場合、プロトタイプに 用いる廉価な Linux 搭載のターゲットボード、教育プログラム、 受託開発やサポート、コンサルテーションなどの支援プログラムを統合的に提供可能なベンダは限られてしまう。

今回、(株) イーエルティより発売された「組込み Linux 評価 キット」(写真  $\mathbf{1}$ ) は、組み込み Linux として定評があり使用実

〔図 2〕組込み Linux 導入パス/サポート体制



績も豊富な MontaVista Linux Professional Edition をベースとして、国内で入手の容易なターゲットボードのボード依存部分である LSP (Linux SupportPackage) と Linux のブートに必要なブートローダをポーティングして、購入後すぐに利用できるパッケージとして提供されており、Linux 導入の入り口としての要素を備えている。表4に「組込み Linux 評価キット」の概要を示す。

「組込み Linux 評価キット」による評価が終了後の製品開発におけるサポートについては、強力なパートナシップをもつモンタビスタジャパンが提供する優秀なサポートを受けることが可能で、評価システムと同じ組み込み Linux を引き続き利用できる。

また、「ToDo(トド)」と称されるアプリケーション開発に必要な日本語変換システムやブラウザなどのコンポーネントをリーズナブルな費用で評価可能なソリューションが提供されており、製品開発に必要な要素を統合して調達可能となっている。さらに、エンジニアのスキル向上のため、「組込み Linux 速習コース」や「ブートローダポーティングコース」などの教育プログラムも利用可能となっている(図2)。そのほか、Linux 開発環境を含めたJTAGプローブや、IDEなどの Linux 開発環境の提供も行っている。

いずれも、組み込み Linux をスマートに導入する上で必要となるソリューションをシームレスに提供することにより、組み込み Linux を搭載した製品開発を容易に行えるソリューションを提供している。詳細は、以下の Web サイトを参照いただきたい。

http://www.emblit.co.jp/

次回は、「組込み Linux 評価キット」の詳細などを解説する予定である。

やまなか・まさる (株) イーエルティ

# ファイアウォール, 帯域管理装置などのプラットホームとなる

# InterWay/GB] の概要

青木 弘/新井雅樹/遠藤俊也/鈴木明彦/中井清元

#### はじめに

「アプライアンス機器」とは、特定機能に特化したハードウェア/ソフトウェア一体型の専用装置のことである。専用装置化により、操作が簡単で、導入期間の短縮、使いやすさなどを実現している。筆者の会社〔(株) PFU〕では、負荷分散装置、帯域管理装置、ファイアウォール、ウイルスウォールなどの各種アプライアンス製品を開発/提供している。また、これら製品で実績のあるハードウェアを、ソフトウェアベンダ、システムインテグレータ、ネットワークインテグレータなど向けにアプライアンス用ハードウェアプラットホームとして提供している。

#### 1 製品の概要と特徴



#### 1.1 概要

InterWay/GBは、IA (Intel Architecture) ベースのラックマウント (1U) の筐体にギガビット Ethernet のポートを 4 ポート標準装備している。マザーボードから筐体まで自社開発を行い、表示/操作機能の装備、24 時間 365 日連続運転を前提とした高信頼性の実現、長期提供の実現、IDC (Internet Data Center) 用途を配慮した前面ケーブリングの採用など、高性能アプライアンス構築に最適なハードウェアプラットホームをめざして開発した。また、InterWay/GBへのアプリケーションソフトの実装を補助する Linux ベースの開発キットも提供している。図1に外観を示す。

#### 1.2 製品の特徴

図2に内部レイアウト図、図3に前面/背面図を示し、特徴

#### 〔図 1〕InterWay/GB の外観



を説明する.

#### ● Gigabit Ethernet × 4 ポートをマザーボードに標準搭載

1) 高速で柔軟性に富むネットワーク接続

Gigabit Ethernet コントローラ「Intel 82544GC」4個をマザーボードに搭載し、独立した MAC アドレスを割り付けた4系統の10Base-T/100Base-TX/1000Base-T のLAN インターフェースを標準装備した。

#### 2) 処理性能

ギガビットインターフェースに応じた処理性能を実現するため,プロセッサに Pentium III  $1.26 \mathrm{GHz}(2$ 次キャッシュ  $512 \mathrm{K}$  バイト),システムチップセットに ServerWorks 製「HE-SL」を採用した.

#### 3) 高速メモリアクセス

メインメモリは、PC133の512MバイトDIMM2枚(ECC付き)を実装し、合計1Gバイトである。最大メモリ転送レートは、2枚のDIMMに対しインタリーブアクセスを行うため、PC133メモリの2倍となる2.1Gバイト/秒である。

#### 4) 高速データ転送と広いバス帯域

PCI バスを 3 系統装備している、 2 系統は 64 ビット/66MHz PCI バスで高速なデータ転送を実現している。 64 ビット/66MHz PCI バスのうち 1 系統にはギガビット Ethernet コントローラを接続しており、もう 1 系統は拡張 PCI スロット用である。 残る 1 系統は 32 ビット/33MHz PCI バスで、IDE インターフェース、レガシーデバイスなどを接続している。

# ◆ システムの適用範囲を広げる 64 ビット/66MHz PCI 拡張スロットを装備

64 ビット/66MHz PCI拡張スロットを2スロット装備している.ファイバチャネルを実装し、ネットワークストレージアプライアンスへの展開や SSL(Secure Sockets Layer)アクセラレータカードを装備するなど、ユーザーのアプライアンス構築企画に柔軟に対応できる.

#### ● 24 時間連続運転・長期安定供給を前提とした設計

部品採用においては、Embedded Intel Architecture Processorの採用、UNIX サーバ用電源ユニットの採用など、長寿命/高信頼部品を選択し、さらに、厳密な冷却設計により、24時間×365日×5年の連続運転を可能する信頼性と装置寿命



を確保した.

#### 1) アプライアンス向け高信頼性機能を装備

1 チップマイコン,センサおよび CPLD (Complex Programmable Logic Device)で構成した外部レジスタからなる RAS 機能をオンボードで実装している.

●オンボードの監視機能により異常を検知しLED,液晶パネルなどで通知

電源監視、CPUファン/装置ファンの監視、CPU温度監視、吸気温度監視機能をオンボードに実装している。異常を検出すると警告 LED を点燈、割り込みを発生し、OS が動作可能状態であれば異常処理を起動できる。また装置前面の液晶パネルに異常内容を表示する処理を実装し、迅速なトラブル対応を実現できる。ファン異常検出の場合に OS が動作不可状態だと、一定時間後にハードウェアで電源を切断する。

● ウォッチドッグタイマ機能によりシステムハングアップも素 早く検出可能

0.25 秒から 32 秒の間で可変のウォッチドッグタイマを装備している.本機能を使用するとシステム異常をすばやく検出可能で、二重化システムでの切り替えを高速化できる.ウォッチドッグタイマで異常を検出したときは、割り込みを発生させ OSの異常処理を起動する. OS が動作不能の場合は 1 秒後にハードウェアにより再起動または電源オフを行う. 再起動か電源オフかは設定可能である.

#### 2) 24 時間連続運転を支える冷却設計

1Uサイズの薄型筐体,24時間連続運転,装置寿命5年を前提としたネットワーク装置の条件下で,信頼性と装置寿命を確保するには、厳密な冷却設計を行うことが重要で欠かせない。

本装置は、熱と空気の流れをシミュレーションする 3 次元熱 流体解析を駆使し、筐体レイアウト、マザーボード上の部品配 置などを検証し、設計へのフィードバックを実施した。

#### ・システム冷却

本装置は前面に表示パネルや I/O ユニット、コネクタを集中的に実装するため、前面の吸気面積を十分に確保することが困難なレイアウトとなった。さらに前面から吸気し後面へ排気するラックマウント装置の制限があり、上面/側面からの吸気は行わないものとした。そのためファンのサイズは筐体高さの制約から 40mm 角とし、吸引力を強化するため静圧が大きいファンを選定した。ファンの個数は、装置内部の空気温度上昇を15℃以下におさえるため、電源ユニットの冷却に1個、マザーボード部品の冷却に1個、3.5インチディスク用に1個と合計3個の軸流ファンを実装し、装置内で発生する約100Wの熱を排出させている。

#### • CPU/システムチップセットの冷却

装置内で発生する熱の約40%はCPUとチップセットが占めている。その中でもっとも発熱密度が高いCPUは、最大約30W発熱する。これを冷却するため、局所冷却用CPUクーラを使って冷却している。このCPUクーラは軸流ファンとヒート

#### 〔図2〕内部レイアウト



#### 〔図3〕前面/背面図





シンクを組み合わせたもので、装置高さ制約より薄いものを選定する必要があった。しかし薄いものは一般的に放熱性能が劣る。そこでアルミと銅フィンを組み合わせたハイブリッドヒートシンクを採用することで、冷却性能を向上させた。さらにCPUクーラから排気された熱風は、システムファンによりすみやかに装置外へ排熱される構造を採った。

図4にシミュレーション用の解析モデルと CPU 断面の温度 分布, 風速分布を示す. 次にシステムチップセットの冷却だが,



チップセットも高速化にともない数年前の CPU 並みに発熱する。この冷却にはピン型ヒートシンクを採用し、高い放熱性能を得るためフィン高さを 18mm、25mm の 2 種類用意し、発熱量の大小によりフィン高さを決めた。

これらの冷却部材により各部品の動作保証温度を満たし、24時間365日連続運転を前提とした冷却性能を実現している。ま

た冷却性能だけでなく、冷却コスト/組み立て性/保守性にも十分考慮したものとなった。

#### • アプライアンス向け簡単操作機能などの装備

#### 1) 表示/操作機能

装置前面に8桁×2行の液晶パネル,5方向の操作スイッチがあり,簡単なシステムメニューの表示や操作ならば装置単体

#### 〔図4〕熱解析結果例





で行える。また、ソフトウェアからの制御も可能な2色の電源 LED、警告 LED および割り込みを発生させてメンテナンス処 理などを起動可能な割り込みスイッチも装備しており、ディス プレイ/キーボード/マウスレスシステムの構築など、簡単運用 の実現を支援するハードウェア機能を備えている。

#### 2) コンパクトフラッシュスロットの装備

装置前面パネル内に、Type Iのコンパクトフラッシュスロットを装備している。これにより、たとえば現地インストール時の個別設定情報提供などに、コンパクトフラッシュカードを利用できる。また、コンパクトフラッシュからのブートも選択可能であり、ディスクレスシステムの実現も可能である。

#### 3) 各種インターフェースの装備

装置背面にシリアルポートを2ポート装備し、コンソール装置の接続と UPS 装置の接続などに利用できる。また、アプライアンス装置の供給者が行うインストール作業、トラブル調査など向けに、ディスプレイ/キーボード/マウスインターフェースも装備している

#### • IDC での設置に配慮した設計

LANポートは装置前面に配備し、スイッチなどのネットワーク機器との接続性を向上させている。また、装置の前面背面で連動した Mark LED付きスイッチを装備し、19インチラックに多くの装置が高密度で搭載されている状態でも、操作対象とする装置を簡単に識別できる。さらに、奥行きの短いネットワーク機器向けラックでの設置を考慮し、1Uの薄型サイズで装置奥行498mmの小型化を実現している。

#### ■ ユーザーアプリケーションソフトの実装に使用する Linux ベースの開発キットを提供

InterWay/GBでは、アプリケーションソフトを組み込む際のソフトウェア開発に使用する InterWay/GB 開発キットを提供している。これは、InterWay/GBの本体装置、ハードウェアマニュアルとともに、InterWay/GBの独自機能を制御するためのサンプルソフトウェアと開発を支援するサポートを提供する.

サンプルソフトウェア CD-ROM には、液晶パネル、操作スイッチ、RAS 機能など InterWay/GB の固有ハードウェア制御機能を使用するためのドライバ、コマンド、ライブラリ(ソー

スコード、ドキュメントを含む)を収録している。また、インストール用 CD-ROM を作成する際の InterWay/GB 固有機能の修正/追加に関するヒントなども含んでいる。これらのサンプルソフトを使った機能実装例を、以下に示す。

- 1) 固有ハードウェア制御機能を利用した、ハードウェア異常 の検出、表示機能
- ●温度異常、ファン異常を検出時に AlarmLED を点燈し、液 晶パネルに異常内容を表示
- 2) 液晶パネルと操作スイッチを使用した簡易メニュー表示や 簡易設定機能
- ●装置動作(システム停止、再起動など)の指示
- IP アドレスやネットマスクなどの設定
- ●現在の動作状態(ネットワーク接続状態,負荷など)の表示なお,本開発キットに添付されるサンプルソフトウェアの使用条件は、ソフトウェアライセンス規約である GPL (GNU General Public License) にしたがう.

#### おわりに

InterWay/GBは、ハードウェアプラットホームとして提供しており、ハードウェアの外観色、ロゴなどのカスタマイズについては商談ごとに相談のうえ対応できる。また、各種ネットワークアプライアンス開発の実績に基づいた、以下のLinux 関連技術についても、InterWay/GBに付随して対応可能である。

- 1) Linux 高信頼性技術
- ■二重化によるフェイルオーバシステムの構築
- 2) Linux 組込み技術
- コンパクトフラッシュを利用したディスクレスシステムの構築
- ●ディスプレイ,キーボード,マウスレスシステムの構築

以上のように、InterWay/GBは高性能アプライアンス装置向けに適合したハードウェアプラットホームとして実現した。今後はより広い業種に採用されるよう、機能の拡充をはかっていく。

あおき・ひろし/あらい・まさき/えんどう・としや/すずき・あきひこ/なかい・きよもと (株) PFU



# 第**2**0

# オブジェクト指向を採用したスクリプト言語 Scriptol N野貴明

今回紹介する Scriptol は、オブジェクト指向を採用したスクリプト言語である。この言語は、実行用のバイナリファイルを作成できるほか、インタプリタを利用して、Webページに埋め込んで実行することもできる。とはいっても Scriptol 自体にインタプリタは実装されておらず、バイナリファイルを作成する機能もない。

Scriptol に搭載されている「コンパイラ」は、Scriptol のプログラムを、C++ もしくは PHP のプログラムに変換するものである



#### インストールと作業環境

Scriptol は、ソースコードが公開されておらず、Windows 版 と Linux 版のコンパイル済みのバイナリが配布されている(**図 1**). 今回は、おもに Windows 版を利用して検証を行った.

Windows版はインストーラ形式になっており、指示にしたがって簡単にインストールを行うことができる。今回は、Windows 2000が動いているマシンへのインストールを行ったが、とくに問題は発生しなかった。なお、Linux版はtarballで配布されて

#### DATA

名称: Scriptol

作者: D.G. Sureau 氏

Web サイト: http://www.scriptol.com/

対象 OS: Windows, Linux

現在のバージョン: 3.4(2003年4月現在)

おり、それを展開すれば必要なものは中にすべてそろっている。 さて、Windows 版も Linux 版も基本的な機能はまったく同 じで、インストールされたファイルの構成もほぼ同じである。

ディレクトリの中を見てみると、Scriptolの本体である solc (C++へのコンバータ)、solp (PHPへのコンバータ)、サンプルプログラム、プログラムのビルド時に利用するライブラリなど、いくつかのファイルが置かれている(**図2**).

る. この IDE は、見た目はシンプルなものだが、キーワードのハイライト機能もきちんと備えており、スクリプトの作成から、C++、PHPへのコンパイル、ビルドや実行まで行うこと

また、Windows版には、IDE(統合開発環境)が付属してい

(図1) Scriptolの配布元(http://www.scriptol.com/)



(図2) Windows 版の Scriptol のファイル群(コンバータやマニュアル、サンプルプログラムなどがまとめて入っている)



#### 〔図3〕 Windows 版の IDE



ができる(図3)

この IDE のエディタは、Scriptol だけでなく、C++、HTML といったファイルのハイライト表示にも対応しているため、C++ や PHP に変換し終わったプログラムについても、表示/編集を行うことができる.

ちなみに、Linux 版の IDE は公開されていないが、エディタの設定ファイルを見ると、Windows 向けの記述のほかに、Linux 向けの記述も見られるので、Linux 版も今後公開されるようだ。



#### 言語仕様

では続いて、Scriptol の言語仕様について見ていくことにする。Scriptol のサイトには「7 rules for a programming language」というドキュメント  $^{\pm 1}$  が掲載されており、そこに言語をデザインするにあたって作者が定めた七つのルールが書かれているので、まずはそれを見ていただきたい。その七つとは、次のようなものである。

- 1. 人間の思考をそのままプログラミングできること
- 2. 安全であること
- 3. 他の言語との共通点をもつこと
- 4. 客観性をもつこと
- 5. 片寄った言語にしないこと
- 6. 移植性が高いこと
- 7. 学ぶのが簡単であること

このドキュメントには、それぞれのルールの詳しい意味についても述べられているが、その内容についてはここでは省略する。これらのルールからも、Scriptolが「これまでできなかったことを実現する」というよりは、「なるべくわかりやすく、簡単に物事を行う」ということに重点を置いた言語であることがわ

注1: http://www.scriptol.org/seven.php

#### 〔リスト 1〕 簡単なサンプル

```
text factorize(int x)
  int d.a
  text ans = x.toText() + " = "
  while x>=4 and x \mod 2=0
    ans + " 2 * "
    x / 2
  /while
  d = 3
  q = x / d
  while q >= d
      if x mod d=0
       ans + d.toText() + " * "
        x = q
      else
        d + 2
      /if
  /while let q = x / d
  ans + x.toText()
return ans
print factorize (33201)
```

かる.

さて、実際の言語仕様は、PerlやPHP、Lua、BASICといったさまざまな言語の特徴が取り入れられているという印象を受ける。他の言語と共通点を多くもつことについては、前述した第3のルールでも示されているが、これまで他の言語を使っていたプログラマが無理なく Scriptol を理解できるようにするために、非常に重要視されているようだ。

まず、簡単な Scriptol のサンプルプログラムを**リスト1**に示す。BASIC のように、各構文の終わりは改行で表され、セミコロンなどで明示的に終了させる必要はない点や、制御構文の終わりが「/for」や「/if」といった形で表されるなどの特徴が見て取れる。

#### 変数

Scriptol に存在する変数型は text (文字列), boolean (論理値), int (整数), real (実数), number (数値すべて) といった一般的な変数型のほかに,配列を扱う array型,連想配列を扱う dict型,そしてどんなデータでも扱うことができる dyn型,ファイルを扱うファイル型などの変数型が用意されている.

Scriptolでは、変数をはじめにきちんと定義する必要があり、変数型の指定もその際にきちんと行わなければならない。変数の定義は、C/C++の定義文と似ており、変数型の後に変数名を記述する。また、次のように定義文で変数の初期化を行うこともできる。

int i = 10

さらに,動的な型変換は行われず,たとえば数値を文字列変数に変換するには,次のように書かなければならない.

text t = i.ToText()

このあたりの仕様は、変数型の指定を行わず、動的な型変換をもつのがあたりまえとなっている既存のスクリプト言語とは大きく異なっているが、Scriptolが C++への変換を行うものであることを考えると、仕方がないことなのかもしれない。

また、上記の「i.ToText()」という書き方からもわかるように、各変数型は実際にはメソッドを備えたクラスとなっており、

数値データであれば、toText(テキストに変換)、toInt(整数に変換)といったメソッド、文字データであれば、length(文字列長を取得)、trim(両側のスペースを取り除く)、find(文字列検索)といった、他の言語でもおなじみのメソッドが用意されている.

演算処理の書き方は一般的な言語とほぼ同様だが、たとえば、変数 a の値と変数 b の値を加算して変数 a に格納する、といった場合、次のように記述することができる。

a+b

つまり、演算結果の保存先を明示的に指定しなかった場合、 最初に指定した変数に結果が格納されるのである。これは、三 つ以上の変数を指定した場合も同様である。次の場合にも、演 算結果は変数 a に格納される。

a+b+1

ただし、いちばん左に数値がくるような記述は構文エラーと なる.

1+a+b

#### • 配列/連想配列

続いて、配列と連想配列についてである。配列、連想配列では、どちらも要素は[](大括弧)付きで指定する。

array a
dict d
a[10] = 100
dict["key"] = "TEXT"

配列の要素の範囲は動的に決められ、あらかじめ指定する必要はない。また、各要素はすべてdyn型(どんなものでも格納できる変数型)になるため、同じ配列の中に数値と文字列を混在させることも可能である。また、配列/連想配列にはイタレータの機能があり、begin(ポインタを先頭の要素にセット)、end(ポインタを最後の要素にセット)、inc(ポインタを次の要素に移動)、dec(ポインタを前の要素に移動)といったメソッドを利用して、データを順に操作していくことができる。

a.begin()
while a[] <> nil
 print a[]
 a.inc()

/while

さらに配列は、push(いちばん最後に要素を追加)、pop(最後の要素を取り出す)、unshift(配列の先頭に要素を追加)、shift(配列の先頭から要素を取り出す)といったメソッドを利用し、スタックやキューとして利用することもできる.

#### • 制御構文

Scriptol の制御構文は、比較的充実している. if 文, for 文, while 文, do 文などは、BASIC や C/C++、Perl などの言語でもおなじみのものである。そのほかにユニークなものとしては、while let ブロックがある。これは、while ブロックの最後に演算処理を追加するものである.

Scriptolによるループ処理は、break(ループを抜ける)、continue(その後の処理をスキップし、新しくループ開始点から処理を開始する)による流れの制御が行える。これは、他の言語にもある機能だが、ループ処理の最後でカウンタ変数をインクリメントするような場合、continueを使ったことで、そのインクリメント処理までもがスキップされてしまい、無限ループに突入するといったことが起こる可能性がある。

while let ブロックは、以下のように while で始まり、let で終わるブロックで、let 文に続いて演算処理を記述することで、continue でループがスキップされた場合でも、let 文に書かれた処理だけは実行されるようにするというものだ。

```
int x = 0
while x < 20
  if (x mod 2) = 0
    continue
  /if
  print x
let x + 1</pre>
```

もう一つ、Scriptol の特徴的な制御構文として scan があげられる。これは、配列/連想配列の要素、それぞれについて処理を行いたい場合などに利用する。たとえば、以下のコードは、配列 a の各要素を 10 倍する。

scan a a[] \* 10 /scan

また、scanでは、複数の配列/連想配列を同時に扱うこともできる。その場合は、それらの中でもっとも要素数の少ないものの回数分だけ、ループされる。たとえば、次の場合には、ループは4回行われることになる。

```
array a = (1,2,3,4,5,6)
array b = (1,2,3,4)
scan a,b
  print a[]*b[]
/scan
```

#### 関数

Scriptolでは、関数は関数名を定義する文で始まり、return 文で終わる。たとえば、以下の文は、数値を受け取り、1を加 算して表示する func という関数の定義である。

void func(number x)
 x + 1
 print x

return

関数名を定義する際には、C/C++と同様に戻り値の型、関数名、パラメータを指定する。ただし、Scriptolでは、戻り値として複数の値を指定することができる。たとえば、以下の関数は、戻り値として文字列一つと二つの数値を返す。

text, number, number testfunc

(number src1, number src2)

src1 - 1
src2 + 1

return "TEXT", src1+src2, src1-src2

この場合, この関数を呼び出す場合にも, 以下のように複数 の変数を指定する。

text t
number a,b
t, a, b = testfunc( 10,5)

#### クラス

Scriptol はオブジェクト指向の概念を取り入れており、クラスを定義することも可能である。クラスの定義は、class~/classというブロックで行う。

コンストラクタは、クラスと同じ名前のメソッドとして定義される。デストラクタはないようだ。これは、PHPにデストラクタが存在せず、変換できないためだろう。

class animal

int age

int getAge() return age

void animal()

age = 0

return

void addAge()

age + 1

return

/class

また、「is」というオペレータを利用することで、クラスの継承を行うこともできる。

class cat is animal

boolean isWild

void dog()

isWild = true

return

/class

さて、実際のクラスの使い方だが、オブジェクトはクラス変数を定義した際に生成される。

animal beast

print beast.getAge()

ただし、コンストラクタがパラメータをとる場合には、次のようにクラス名とパラメータを使って生成する.

dog dog1 = dog("pochi")



#### スクリプトのコンパイルと実行

作成したスクリプトは、C++か PHP に変換を行い、実行す

ることができる. それぞれの変換は、「solc (C++への変換)」および「solp (PHPへの変換)」というプログラムで行う.

変換の方法は、コマンドラインからそれぞれのプログラムを パラメータに変換したいプログラムファイルを指定して呼び出 すだけである。

solc test.sol

solp test.sol

すると、solc の場合は「test.cpp」(プログラムファイル)「test.hpp」(ヘッダファイル)の二つのファイルが、solp の場合は「test.php」というファイルが出力される。

また、solcでは、C++への変換の後、C++のコンパイラを起動して、コンパイルおよびビルドを行う機能も備えている.

次のように入力すると、Scriptolから C++ への変換、C++ のプログラムのコンパイルとビルド、実行までをまとめて行ってくれる.

solc -cbr test.sol

Scriptol が対応している C++ のコンパイラは、Borland 社のBorland C++ Compiler と、MinGW <sup>注2</sup> に含まれる gcc である。どちらが利用されるかは、「solc.ini」という初期設定ファイルで指定される。Scriptol がインストールされたディレクトリに置かれた solc.ini は、Borland C++ を利用する設定になっている。今回、筆者が検証した環境は、Borland C++ があらかじめインストールされていたので、サンプルスクリプトのビルドは、まったく問題なくできた。

しかし、どうやらこの初期設定ファイルは、カレントディレクトリにおかれているものを読みにいくようなので、カレントディレクトリ(たいていは、ソースコードが置かれたディレクトリを利用するだろう)に、「solc.ini」を置いておかないと、その設定が反映されない.

solc.iniがない場合, solcは MinGWのgcc を使う設定が標準になってしまうので, Borland C++ しかインストールされていない環境では, エラーとなってしまう. サンプルスクリプトは, solcや標準のsolc.iniと同じディレクトリに置かれているので問題なくコンバイルできるが, 自分で作成したスクリプトは独自のディレクトリで管理したい.

そこで、solc.ini をコピーし、中に書かれているインクルードファイルやライブラリの設定を書き換え、どこのディレクトリからでもきちんとビルドが行えるものを作成した(**リスト2**). このファイルをソースファイルと同じディレクトリに置いておけば、どのディレクトリであっても、問題なくビルド作業を行うことができる.

さて、続いてPHPである。PHPの場合は、インタプリタがインストールされていれば、やはり変換したプログラムをそのまま実行することが可能である。その場合は次のように指定する。

solp -r test.sol

注2: Minimalist GNU For Windows の略. GCCでWindowsのプログラムを作成できるようにしたヘッダファイルとライブラリ群. http://www.mingw.org/

#### 〔リスト 2〕修正を行った solc.ini ファイル

```
compiler=bcc32.exe
options= -a8 -c -C -4 -DBCC -k -O1 -RT- -vi- -Vms -w-par -w-aus -w-use

-w-sig -w-ccc -Tkh30000 -tWC -q -I"c:\(\frac{2}{3}\)program files\(\frac{2}{3}\)scriptol"
linker=ilink32.exe
loptions= -C -Gn -x -c -q
objects=c0x32.obj "c:\(\frac{2}{3}\)program files\(\frac{2}{3}\)scriptol\(\frac{2}{3}\)lib
files\(\frac{2}{3}\)scriptol\(\frac{2}{3}\)c.\(\frac{2}{3}\)program
files\(\frac{2}{3}\)scriptol\(\frac{2}{3}\)c.\(\frac{2}{3}\)b
extension = ".obj"
```

ちなみに、クライアントとして利用している Windows マシンの場合、PHP をインストールしていることはあまりないと思われるが、PHP の Windows 版のバイナリファイルをダウンロードし  $^{t+3}$ 、適当な場所にコピーを行い、php. exe にパスを通すだけで利用が可能になる。変換したスクリプトを直接 PHP で実行するには、以下のように指定する。

php -q test.php



#### 変換の実際

さて、Scriptol は、作成したソースコードは C++ および PHP に変換される。Scriptol と C++、PHP の言語仕様は、見た目の違いはあるものの、記述できることにはそれほどの違いがあるわけではないので、基本的には素直な変換が行われるようだ。ただし Scriptol は、変換先の言語に存在しない機能ももって

ただし Scriptol は、変換先の言語に存在しない機能ももっている。そのため、それらの機能がどのように変換されるのかを調べてみた。

#### • 変数

まずは、存在しない変数型の問題である。まず、C++ に存在しない変数型である number は、double として定義されている。そのほか、text、dyn、array、dict などの変数型は、クラスとしてあらかじめ定義されたものが Scriptol ディレク

#### 〔リスト 3〕テストに用いたサンプル、および C++ と PHP への変換

```
text, int, int AddSub( int a, int b)
  int c = a + b
  int d = a - b
return "AddSub", c, d
```

#### (a) 複数の戻り値をもつ関数

```
array AddSub(int a,int b) {
   int c=a+b;
   int d=a-b;
   return array(dyn("AddSub"))+dyn(c)+dyn(d);
}
```

#### (b) C++ への変換結果

```
function AddSub($a,$b)
{
$c=$a+$b;
$d=$a-$b;
return array("AddSub",$c,$d);
}
```

#### (c) PHPへの変換結果

トリに用意されており、それが利用される。それらのクラスの構造はそれぞれ、array.hpp、text.hppといったヘッダファイルで定義されている。そして、その実体はlibsol.a(もしくはlibsol.lib)というファイルに含まれており、実行ファイル作成時にまとめてビルドされる。

PHPの場合には、Scriptolのもつ変数の機能はほぼ網羅されており、とくにライブラリが呼ばれるようなことはない。

#### • 関数の戻り値

言語仕様の項でも述べたとおり、Scriptol は関数が複数の戻り値をとることができる。しかし、C++も PHPも、関数が返せる戻り値は一つである。そこで、複数の戻り値をもつ関数が、どのように変換されるのかを調べてみた。

テストに用いたサンプル、および C++ と PHP への変換結果をリスト 3 に示す。結果、複数の戻り値があった場合は、array クラスにデータが格納され(変数名は dyn クラスを使って格納されている)、戻り値としてその array クラスが戻されている。array クラスや dyn クラスが、実際の配列、連想配列だけでなく、内部的にも活用されていることがわかる。



#### 日本語の使用

Scriptol はフランスで作られている言語であり、これまで紹介してきた外国生まれのほとんどの言語と同様、日本語の利用はとくに考えられていないが、それは日本語が「使えない」という意味ではない。

たとえば、以下のような文字列として日本語を埋め込んだスクリプトを作成しても、問題なくコンパイル/実行することができる。とくに文字化けなどは起こらない。

```
text a = "あいうえお"
text b = "かきくけこ"
print a+b
```

ただし、Scriptolでは、「\*(アスキーコードで5Ch)」をエスケープ文字として利用している。そのため、文字コードとしてシフト JIS を使っている場合には、注意が必要である。文字コードの一部として5Ch が存在するからである。たとえば「噂(895Ch)」、「欺(8B5Ch)」といった文字などがある場合、文字の後にもう一つ「\*」をつけないと正しく表示できない。さらに、次の例のように、そのような文字が文字列の最後に来てしまった場合、C++/PHPへのコンパイル時にエラーが発生してしまう。最後のダブルクォーテーションが、直前の「\*(5Ch)」によって、エスケープされていると解釈されてしまうためである。

誤: text title = "俺に関する噂" 正: text title = "俺に関する噂¥"

注3: http://www.php.net/からダウンロードできる.

しかし、このエスケープ文字の問題は、C/C++でも同様に発生する問題であり、比較的よく知られているものなので、それほど大きな問題ではないだろう。したがって、Scriptolは、一般的な外国生まれのプログラミング言語程度には、日本語が利用できるということになる。

また、Windows版に付属するIDEでは、まったく日本語が使えない。初期状態では欧米文のフォントが指定されており、日本語が表示できない。IDEのフォントの設定は、同じディレクトリに置かれた「global.properties」というファイルの中で指定されている(リスト4)。しかし、そこで日本語が利用できるフォントを指定しても、やはり日本語を利用することはできなかった。どうやら、画面に表示を行う際に、1バイトずつ処理されてしまい、正しく表示されていないようである。残念ながら、IDEでの日本語の利用は、現時点ではあきらめざるを得ないようだ。

#### まとめ — Scriptol の存在意義

繰り返しになるが、Scriptolは、実際に実行可能なバイナリファイルを作成したり、インタプリタとしてスクリプトを実行することはできない。できることは、ほかの言語への変換だけである。

それなら、最初から C++や PHP で書けばよいのではないか、という意見が出てくることも当然予想される。もちろん、C++や PHP にすでに慣れ親しんでいて、それらの言語でプログラムを作成することがまったく苫でなければ、Scriptolを使う意義はあまりない。

だからといって、Scriptolを C++ や PHP をまったく知らなくても、それらの言語でコードが書けるツール、ととらえることにもやや無理がある。というのも、作成したプログラムに問題があり、コンパイルや実行時にエラーが発生したような場合、まずは変換後のコードから問題を発見しなければならないようなことも考えられるからだ。そんなとき、もし変換後の言語についての知識がまったくなかったら、問題解決は相当難しくなってしまうだろう。

では Scriptol は、どのような人向けの言語なのだろうか。

Scriptol を使う最大のメリットは、C++に比べると、ずっと手軽に書くことができるという点である。言語仕様の策定において作者が決めた「七つのルール」にも、その思想ははっきりと現れている。したがって、Scriptol を使うのに向いているのは、C++ も読むことはできるが、どちらかというと手軽にプログラミングを行いたい人なのだろう。また、PHPやPerlなどのスクリプト言語の経験があり、これからC++の書き方を勉強したいという人の勉強用のツールとしても役立つかもしれない。

この連載では、以前に  $BCX^{\pm 4}$  という、BASIC を C 言語に変換するツールを紹介している。こちらも C がわからない人向

### [リスト 4] IDE の利用するフォントは global.properties で設定されている (抜粋)

```
# Give symbolic names to the set of fonts used
in the standard styles.
if PLAT WIN
    font base=font Verdana size:10
    font.small=font:Verdana.size:8
    font.comment=font:Comic Sans MS.size:9
    font.code.comment.box=$(font.comment)
    font.code.comment.line=$(font.comment)
    font.code.comment.doc=$(font.comment)
    font.text=font:Times New Roman.size:11
    font.text.comment=font:Verdana, size:9
    font.embedded.base=font:Verdana,size:9
    font.embedded.comment=font:Comic Sans MS, size:8
    font.monospace=font:Courier New, size:10
    font.vbs=font:Lucida Sans Unicode.size:10
if PLAT_GTK
    font.base=font:lucidatypewriter,size:12
    font.small=font:lucidatypewriter,size:10
    font.comment=font:new century schoolbook,size:12
    font.code.comment.box=$(font.comment)
    font.code.comment.line=$(font.comment)
    font.code.comment.doc=$(font.comment)
    font.text=font:times.size:14
    font.text.comment=font:lucidatypewriter,size:10
    font.embedded.base=font:lucidatvpewriter.size:12
    font.embedded.comment=font:lucidatvpewriter.size:12
    font.monospace=font:courier.size:12
    font.vbs=font:new century schoolbook.size:12
font.js=$(font.comment)
```

けというよりは、Cもわかるけれど BASIC でプログラミング がしたい人向けといったおもむきのツールだった。Scriptolも、やはりそれに近い位置付けができるのではないか、と筆者は感じた。

また、C++とPHP、両方に対応していることで、同じプログラムを両方の言語に変換することができるため、一度書いたコードの再利用性を高めるために利用するといった使い方もできるかもしれない。

最後にもう一つ、Scriptolを使ってみて感じたことがある。 それは、Scriptolにはおそらく作者である D.G. Sureau 氏のコーディングにおける思想が、非常によく反映されているという点だ、プログラマはみなそれぞれ、コーディングに関する思想や美学をもっている。しかし、使用する言語によっては、その思想を完全にコードに反映することができないかもしれない。

しかし、新しい言語を作成してしまえば、自分の思想をそこに盛り込むのは、既存の言語を利用した場合よりも簡単だろう。 しかも、コンパイラやインタプリタを作らず、コンバータという形にすることで、自分の求める言語を比較的容易に作成することができるのかもしれないということを、Scriptolが示しているような気がするのである。

143

みずの・たかあき

注4: http://bcx.basicguru.com/. 詳細は,本誌2003年3月号の連載「開発環境探訪」を参照のこと.



# Javaアフ

# アル機器の制御

川口幸裕

#### はじめに

前回(2003年6月号)では、XPort評価キットを使って、PC 同上、PCとマイクロコンバータ、PCと加速度センサをそれぞ れ Ethernet を経由してつなげてみた。実際、手元にあるシリア ル機器が何の苦もなくつながったはずである(うまくつながらな かった方は、稿末のメールアドレスまでご一報いただきたい)。 今回は最初に、前回の「おさらい」を含めて XPort 評価キット の説明を簡単に行う. 現在発売されている XPort 評価キットは 正式な製品であり、前回の紹介時のプロトタイプと大きな違い はない、XPort 自体に変更はかかっておらず、評価ボード(写真 1) も変更されていない、細かな違いを表1にまとめる.

本稿は、基本的には表1にも記した XPort Sample Code and Solutions 910-816.pdfの内容に沿って解説する. XPort に搭載されている Web サーバを使い、Java アプレット を使用したシリアル機器との通信手段の詳細を述べる. マニュ アルとサンプルコードの内容、実際に動作させるための手順・ 動作結果などを説明する.



#### Webページの設定について

Java アプレットの説明に入る前に、実際に作成した Web

ページを XPort にダウンロードする方法を説明する。 ラントロ ニクスの製品でWebサーバを搭載したものはいくつかあるが、 これらにおける Web ページデータの取り扱いについては、.cob ファイルというコンテナファイル形式を採用している。.cob形 式は同社独自のものであり、.htm, .html を含む Web ページ の構成要素をすべて、cobファイルに変換することで、取り扱い を簡単にしている. この.cobファイルを作成する手順と, XPort へのダウンロード方法を説明する。なお.htm. .html フ ァイルの作成方法に関しては、それらに関する文献をご参照い ただきたい.

● XPort Installer による Web ページの設定

XPort Installer に内蔵されている.cobファイル作成ツール で、実際に変換対象ファイル群が入ったディレクトリを指定す るだけである(図2). この場合, 64Kバイト以内の大きさに収 まる.cobファイル1個の処理となり,.cobファイルは自動的 に XPort の WEB1 エリアにダウンロードされる.

● WEB2COB による.cob ファイルの作成

XPortのフラッシュメモリは、64Kバイトごとのページ形式 になっている. .cob ファイルが 64K バイトを超えるようであ れば、フォルダを分け、別の.cobファイルに変換する必要が ある. また複数の.cobファイルを作る場合, 前述した XPort Installer ではできない。そのため、WEB2COB という変換ユー

#### 〔写真 1〕XPort 評価ボード



#### 〔表 1〕XPort 評価キットーー正式版とプロトタイプの違い

- ●添付されている「Device Installer」が「XPort Installer」に名称変 更されている. また、Web ページ、ファームウェアのダウンロ ード用のボタンが増えており(図1参照),若干見た目が変わって いる(機能そのものはまったく変わっていない)
- ●XPort 内部のファームウェアが 1.0 Beta 7 から 1.20 にバージョ
- ●マニュアル類が最新のものとなった(Comm\_Port\_Redirector. pdf, XPort FAQs.pdf, XPort DS 910-815.pdf, XPort product\_brief.pdf, XPort\_UM\_900-270.pdf) -- これら はラントロニクスの Web ページ (http://www.lantronix. com/)から最新版をダウンロード可能
- ●XPort Sample Code and Solutions 910-816.pdf: Java アプレットを使用したシリアル機器のコントロールに関してのマニ ュアル. このマニュアルはラントロニクス社の Web ページには掲 載されておらず、XPort 評価キットに付属している. 同時にこのマ ニュアルに沿ったサンプルアプリケーションが添付されている



#### [図1] XPort Installer



ティリティが用意されている。このプログラムは XPort Installer をインストールしたディレクトリに入っている。また、このプログラムは mimetype.ini というファイルを常に参照するので、かりに他のディレクトリで.cob ファイルを作成したい場合、このファイルも一緒にコピーする必要がある。

サンプルコードとして用意されているものを別ディレクトリ にコピーして試してみる.

C:\YTESTWEB (図3)

C:\TESTWEB\WEBA (**区4**)

C:¥TESTWEB¥WEBB (図5)

WEB2COB.exe と mimetype.ini は C:\\*TESTWEB にコピーしておく. データを WEBA と WEBB に分けているのは, 64K バイトに収まらないからである. また thermostat.zip は, 実際に動作する Java Applet のコンテナファイルである.

WEB2COB を実行すると(**図 6**), WebA.cob, WebB.cob という二つのファイルができあがる.

● Webページのダウンロード

できあがった.cobファイルは、XPort InstallerでXPortにダウンロードする(図**7**).

また、TFTP クライアントによる Web ページのダウンロードも可能である.Windows 2000/XP には TFTP クライアント

#### 〔図 2〕 XPort Installer による.cob ファイルへの変換





#### 「図3] TESTWEB ディレクトリの内容



#### 〔図4〕WEBAディレクトリの内容



#### 〔図 5〕WEBB ディレクトリの内容



#### 〔図 7〕.cob ファイルを XPort Installer で XPort にダウンロード



が装備されている. これを使い, XPort Installer を使わない で.cob をインストールすることもできる.

C:\TESTWEB> tftp -i 10.2.20.115 PUT WebA

#### 〔図 6〕 WEB2COB の実行



.cob WEB1

C:\TESTWEB> tftp -i 10.2.20.115 PUT WebB

.cob WEB2

XPort 側のファイル名として、WEB1、WEB2  $\sim$  WEB6 までを指定する。これは、それぞれ XPort 上のフラッシュメモリのページに相当する。

ここまでで、WebページをXPort にダウンロードする方法は理解いただけたと思う。難しい作業ではないので、ツールの使い方さえ間違えなければ、問題なくWebページの設定ができるはずだ。

#### Web Manager

XPort には標準で、Web Manager がデフォルトのWebページとして登録されている(図8). このWebページはブラウザを通して、XPort の諸情報を変更することができる。実際にこれ自体もJava アプレットで記述されている。



### Java Applet

それでは本題の Java Applet を使ったシリアル機器のコントロールを行ってみよう. サンプルとして用意されているのは, 先ほど使用した WebA.cob, WebB.cob, それと PC側のアプ



#### (図8) Web Manager



(図9) RS-232-C ポートをもった PC でアプリケーションを動作させる



〔図 10〕 Java Applet の起動



リケーションである。実際にこのサンプルアプリケーションを動作させるために、PCを2台用意する。1台はRS-232-Cポートが必須である。もう1台はネットワークインターフェースをもったもので、ブラウザが動作する環境が必要である(RS-232-Cポートとネットワークインターフェースを両方もったPC1台でもかまわない)。

RS-232-C ポートをもった PC 側のアプリケーションは Visual Basic で記述された室温制御をシミュレーションするプログラム (ファイル名: thermostat.exe)で、RS-232-C から送られたデータを反映させ、また変更がかかったときに、そのデータを RS-232-C に送出するものである。このアプリケーションで制御するものは、コントローラのオン/オフ、暖房/冷房/オートモードの設定、ファンのオン/オフ、冷房/暖房のスイッチを入れるための温度(しきい値)の設定となっている。このアプリケーションで PC は仮想のシリアル室温コントローラとなる。

2台のPC間をXPort評価ボードで接続する.XPort評価ボードのRS-232-Cポートを同じくRS-232-CポートをもったPCにストレートケーブルで接続する.XPort評価ボードのEthernetをもう1台のネットワークインターフェースをもったPCに接続する.直結するのであればクロスのEthernetケーブ

ル, ハブを介するのならストレート Ethernet ケーブルでかまわ わない

RS-232-C ポートをもった PC で、先ほどの Visual Basic で記述されたアプリケーションを動作させる (**図9**). ボタンを押すと温度設定や、ファンのスイッチが切り替えられる. この状態で、Ethernet 側の PC で XPort Installer を起動し、ポートには10001 を指定して Telnet を立ち上げる. するとコンソール画面に3 文字のデータが表示される. これは室温コントローラから送られてくる現在のステータスである. 実際に室温コントローラを操作すると、この3 文字のステータスデータが変化する. この段階では、前回述べたとおりシリアル機器の情報をEthernet 接続された Telnet 端末で受信できていることを意味する.

続いて、ネットワーク接続されている PC 側でブラウザを起動する。アドレスに xxx.xxx.xxx.xxx/thermostat.html と入力する (xxx.xxx.xxx.xxx は XPort に割り付けた IP アドレス)。室温制御アプリケーションとほぼ同じ画面の Java Applet が起動する (図 10).

室温制御アプリケーション,ブラウザ側の Java Applet のどちらのステータスを変更しても 互いに同期が取られ、同じステ





### その他の Java Applet

今回の新しい評価ボード用 CD-ROM に含まれているサンプルアプリケーションには、XPort を使うための Java Applet が収録されて

いる. XPort用ユーティリティとして CBXConfig. Java というファイルが含まれており、その中には**図 A** のようなものが含まれている. これらは XPort をさらに使いこなすために用意されているもので、これがなければ XPort の基本機能を簡単に使いこなせないというわけではない.

#### 〔図 A〕 CBXConfig.Java の内容

#### ・XPort 設定ユーティリティ

```
メール発信機能の設定
public void setEmailConfig()
public void reboot()
                                                    IPアドレスとポートの設定
public CBXConfig(InetAddress ipa, int port)
                                                    IP アドレスの設定
public CBXConfig(InetAddress ipa)
                                                     ディスコネクト
public void disconnect()
public int monitor(int portn)
                                                     モニタリング
                                                     リモートIPの設定
public byte setRemoteIP(String rip, int port, int mode)
public void reset()
                                                     リセット
                                                     コンフィグレーションの反映
public void setConfig()
```

#### ・その他文字列操作

public int stringToPort(String \_given), private byte[] stringToIp(String \_given),
private int toInt(byte given)
private String byteToHex(byte b), private String charToHex(char c)

#### ・サンプルコード

```
public void reboot()
   ctp.disconnect();
   sleeper(5);
public void reset()
   int i;
   data[0] = 0x00;
   data[1] = 0x00;
   data[2] = 0x00;
   data[3] = (byte) RESET;
   byte[] btmp = Password.getBytes();
   data[4] = btmp[0];
   data[5] = btmp[1];
   ctp.send(data):
  ctp.disconnect();
   sleeper(5):
public void setConfig()
   int i;
   odata[0] = 0x00;
   odata[1] = 0x00;
   odata[2] = 0x00;
   odata[3] = (byte) PUTSU;
   for(i = 0; i < 120; i++)
     odata[i+4] = nSetup[i];
  ctp.send(odata);
   ctp.disconnect();
   sleeper(5);
public int stringToPort(String given)
   int temp = sti(_given);
```

```
if((temp > 0) \&\& (temp <= 0xffff))
     return (temp);
  return(-1);
private byte[] stringToIp(String _given)
   byte[] retval = new byte[5];
   retval[4] = -1; // setting error
   StringTokenizer st = new
      StringTokenizer(_given, ".");
   if (st.countTokens() != 4)
      return(retval);
  int[] temp = new int[4];
  for (int i = 0: i < 4: i++)
     temp[i] = sti(st.nextToken());
retval[i] = (byte) (temp[i] & 0xff);
     if (temp[i] != toInt(retval[i]))
        return(retval);
  retval[4] = 0;
  return(retval);
public void sleeper(int given)
   try
      Thread.sleep(given*1000);
   catch (Exception ex)
      System.out.println("ERROR in sleeper("
         + given + "):" + ex);
```



ータスになる. これにより、Java Applet と RS-232-C を介して アプリケーションが通信を行っていることが確認できる. なお、 以降掲載するリストは XPort 評価キットとサンプルに付属して いる CD-ROM からの抜粋であり、コメントは筆者が日本語化 している.

実際に XPort を介してシリアル側にデータを送るための Java Applet ソースコードは、**リスト1**のとおりである.

この tcpip.java は全体では 200 行ほどで、Java Applet からの TCP/IP のコネクション、データの送受信などが含まれている。 XPort を通したシリアル機器への通信のための機能はすべて網羅されている。 アプリケーションからのコーリングシーケンスはリスト2のようになる.

この二つのアプリケーション、Visual Basic 版と Java Applet 版は、3文字のデータを送受信することで同期を取っている。実際に暖房/冷房などのスイッチに関しては、3文字のデータの先頭バイトによりケース分けをしており、実際の温度に関してはその後の2文字のデータで通信を行っている。このように、実アプリケーション(シリアル機器)との通信を確立することで、Java Applet のようなブラウザレベルでのコントロールが可能となる。これは XPort に内蔵された Web サーバを使ったアプリケーション事例の一つととらえていただきたい。

Java Applet を使ったシリアル機器の制御は意外と簡単だということを理解していただけたのではないだろうか. サンプル

#### (リスト 1) XPort を介してシリアル側にデータを送るための Java Applet ソースコード(topip. java より抜粋)

コードもふんだんに用意されており、Java に精通した方ならすぐにアプリケーション開発ができると思う。また、XPortへの設定ユーティリティも用意されており(コラム1参照)、これらを使用することで、より複雑なアプリケーションも短期間で開

## 33A2

### ラントロニクス社のその他製品

ラントロニクス社は、XPort以外にも「箱もの」と呼ばれるデバイスサーバ、ターミナル/コンソールサーバを用意している。デバイスサーバに関しては、基本的な機能はXPortと同等である。RS-232-C/422/485インターフェースをもち、これらの対応機器をEthernetに接続できる。XPortはシリアル機器への内蔵を前提に開発されているが、場合によっては外付けのほうが好ましい場合にはこのようなデバイスサーバをおすすめする(写真 A).

(写真 A) 外付けデバイスサーバの例(UDS100)



ターミナル/コンソールサーバは、シリアル1対ネットワーク1の構成であるデバイスサーバに比べ、複数のシリアルポートをもったものである。4ポートから最大48ポートまでもっており、アプリケーションにあわせた選択肢が広くなっている。これらはつの Ethernet ポートをもち、複数のシリアルポートを一括でコントロールできる。具体的には複数の XPort と Ethernet ハブがつの筐体に入ったものだが、複数ポートを一括コントロールするためのより高いパフォーマンスをもち、セキュリティやサポートされているネットワークプロトコルはデバイスサーバに比べて広範囲に対応する(写真B).

(写真B) ターミナル/コンソールサーバの例(ETS16P)







### 〔リスト 2〕アプリケーションからのコーリングシーケンス

(thermostat.java より抜粋)

```
import java.awt.*;
import java.awt.event.*;
import java.awt.image.*
import java.applet.Applet;
import java.io.*;
import java.net.*;
import java.util.*;
import netscape.javascript.*;
class ThermostatCanvas extends Canvas implements
MouseListener
   // IP stuff
  public tcpip gtp;
  public synchronized void sendHeatingSetpoint()
     // このファンクションは暖房のスイッチを入れるため
     // の温度設定をXPortを通して室温コントロール
     // アプリケーションに送るものです.
     if (gtp != null)
        String s = new String("H" +
        new String(new Integer(iHeatingSetpoint).toString())
        + "XL") .
        gtp.send(s);
  }
```

発できる.

#### おわりに

前回記した SDK に関する解説は、残念ながらリリースが原稿執筆に間に合わなかったため、解説することはかなわなかったが、本号が発売される頃にはリリースされているはずである。 XPort は、CPU/メモリ/入出力装置を装備した一つのシステム制品である。 内蔵可能でかつプログラマブルということで

XPortは、CPU/メモリ/人出力装置を装備した一つのシステム製品である。内蔵可能でかつプログラマブルということで、シリアル機器に対するプログラマブルコントローラとして使うことも十分考えられる。最近ではフラッシュメモリにデータを蓄えるデータロガー、シリアル機器同上を直接結ぶコントローラなど、さまざまな用途が考えられている。これらの機能を実現するためには、やはりSDKの存在は無視できない。Java Applet は入出力に関する選択肢を広げるものだが、機能そのものの拡張にはやはりSDKが必要だと思う。リリースされしだい、このあたりの詳細を調査する予定である。興味のある方は以下のメールアドレスへご連絡いただきたい。

#### ■「XPort」に関する問い合わせ先

橘テクトロン(株)

・営業関係問い合わせ先: sales.lantronix@tachitec.co.jp

●技術的ご質問: support.lantronix@tachitec.co.jp

かわぐち・ゆきひろ 橘テクトロン(株)

# 音楽配信技術の最新動向

# ピアツーピアを利用した配信と

# OggVorbis のエンコード

















前回は、**OggVorbis** ファイルをデコードするプログラムについて説明しました。今回からは、**OggVorbis** ファイルを作るプログラム(エンコーダ)を作ってみましょう。

その前に、インターネット上で見つけた、ピアツーピアを利用した音楽配信についての話題を少し取り上げます.

### ピアツーピアを利用した配信

本連載でも何度か取り上げましたが、インターネットを利用 した音楽配信の先駆者であるミュージシャンの平沢進氏が、 ネット上でイベントを行いました.

平沢進氏はコンピュータを介し、観客の意志が次々と反映され、ステージと観客が対話しながら進行する「インタラクティブライブ」を行ってきましたが、このイベントも、その宣伝とテストを兼ねて行ったようです。

いままでにも会場の観客だけではなく、ネット上から接続した「在宅オーディエンス」とも Web アプリを通じて対話する実

験をしてきましたが、それに加えて今回のライブでは、より大がかりにピアツーピア方式でライブを中継する計画です。ライブ本番は5月の連休中に行われます。どのように進められたかは次号で報告します。

インタラクティブライブを説明している Web サイトを**図1** に、今回のインタラクティブライブ「LIMBO-54」の Web サイトを**図2** に示します.

今回はストリーミングを中継するソフトとして SHOUT cast, Peer Cast を使用することを推奨しています.

通常,ストリーミングというとサーバがあり、そこに数多くのユーザーが接続し、サーバはユーザーの接続数だけセッションを確立しなければなりません。

ピアツーピアの場合、発信元のサーバは2次サーバにセッションを確立するだけで済みます。2次サーバは3次サーバにセッションを確立するだけです。かりに2ユーザーずつ発信元サーバ→その次→その次と理想的に接続すれば、N次サーバの時点で2のN乗だけのユーザーが音楽を聴くことができます。

#### (図1) What is the interactive live?

(http://plaza20.mbn.or.jp/~ghost/intera.htm)



(**図2**) Susumu Hirasawa Interactive Live Show 2003 [LIMBO-54] (http://premium.nikkeibp.co.jp/il2003/index.shtml)



#### 〔図3〕ピアツーピアを使用したストリーミングの概念。



〔図4〕通常のストリーミングの概念



たとえば 16次サーバまで接続できたとしたら,65535-1人が 音楽を楽しむことができます (図3). 通常の方式でそれだけの 人数がアクセスすると,回線の太さやサーバの容量を考えなければなりません (図4). ピアツーピアの場合,それが大きな利点となります.

ピアツーピア方式のストリーミング配信技術については、次 号で詳細に説明する予定です.

### OggVorbis のエンコード

さて、今回の本題である Ogg Vorbis のエンコードについて説明します。今回は、そのために必要となる libvorbisenc API を説明します。

libvorbisenc の現行バージョンは非常に単純な構造です。エンコードエンジンを適切にセットアップする初期化機能を含み、今後の変更にも対応する。エンコーダセッティングのコントロール機能も含んでいます。

libvorbisencルーチンは、すべて「vorbis/vorbisenc.h」の中で宣言されます.

#### • 関数: vorbis\_encode\_init

この関数は、その名のとおり初期化処理をします。必要な構造体にパラメータを設定し、適切なエンコードができる環境を構築します。

なお、この関数は固定ビットレートを用いるときに使います. ここで指定する最大ビットレートや最小ビットレートは一種 のコメントとして、作成されたエンコードデータに記録され ます.

使う側がビットレートの最大値や最小値として使用します。

この処理の前に、libvorbis APIの初期化処理であるvorbis\_info\_init()を呼んでおきます。そしてもちろん、エンコードの後には、vorbis\_info\_clearを呼ばなくてはなりません。

プロトタイプをリスト1に示します.

以下, 引き数を説明します.

- ▶ vorbis\_info \*vi 初期化したい vorbis\_info 構造体を指定します。
- ▶ long channels エンコードしたいチャネル数をセットします.
- ▶ long rate 入力音源のサンプリングレートを指定します.

#### 〔リスト 1〕vorbis\_encode\_init のプロトタイプ

#### (リスト 2) vorbis\_encode\_init\_vbr のプロトタイプ

#### 〔リスト3〕vorbis\_encode\_ctlのプロトタイプ

extern int vorbis\_encode\_ctl(vorbis\_info \*vi,int number,void \*arg);

#### ▶ long max bitrate

エンコードデータに記録される最大ビットレートです。これはこのデータを使う側が、ビットレートの最大値として使います。

▶ long nominal\_bitrate この値で指定されたビットレートでエンコードされます.

#### ▶ long min bitrate

エンコードデータに記録される最小ビットレートです. これは, このデータを使う側が, ビットレートの最小値として使います.

そして、戻り値がゼロ以外ならエラーです。

#### • 関数: vorbis encode init vbr

この関数は、その名のとおり可変ビットレート用に初期化処理をします.必要な構造体にパラメータを設定し、適切なエンコードができる環境を構築します.

この処理の前には、やはり libvorbis API の初期化処理である vorbis info init()を呼んでおきます.

もちろん, エンコードの後にはvorbis\_info\_clear を呼ばなくてはなりません.

プロトタイプをリスト2に示します.

以下, 引き数を説明します.

#### ▶ vorbis info \*vi

初期化したい vorbis info 構造体を指定します.

#### long channels

エンコードしたいチャネル数をセットします.

#### long rate

入力音源のサンプリングレートを指定します.

#### ▶ float base\_quality

0から1の間の正の値でエンコード品質を指定します.

そして、戻り値がゼロ以外ならエラーです.

#### • 関数: vorbis encode ctl

公式マニュアルにはまだ実装されていないと書いてありますが、すでにリリースされているようです.

この関数を使ってエンコードを行います.

プロトタイプをリスト3に示します.

以下,引き数を説明します.

#### ▶ vorbis info \*vi

初期化済みでパラメータをセットした vorbis\_info 構造体 を指定します.

#### ▶ int number

エンコードの際には定数 OV\_ECTL\_RATEMANAGE\_GET を セットするようです. 値は 0x10 です.

#### void \*arg

構造体 ovectl\_ratemanage\_arg を指定します. ここに処理されたサンプリングレートなどが戻ります. 実際のサンブルプログラムを作成する際に詳しく検証します.

そして, 戻り値がゼロ以外ならエラーです.

次回は、libvorbisenc APIを使って簡単なサンプルプログラムを作成してみます。

きし・てつお

### x86CPUだけでもマスタしたい

# 

第19回 制御転送命令

大貫広幸

これまで、x86系 CPU の汎用命令に分類される転送、演算、ビット/バイト/フラグに関する命令について説明してきました。x86系 CPU の汎用命令も、残るはジャンプ/コールに関する命令と、ストリング命令と呼ばれるバイト列を扱う命令群のみです。そこで今回は、ジャンプ/コールに関する命令について説明することにします。

x86 系 CPUでは、ジャンプ/コールのようなプログラムの実行を制御する命令のことを「制御転送命令」と呼びます。

### プログラムの実行を制御する命令の種類

x86 系 CPU のプログラムの実行を制御する命令としては、表 1に示すような「制御転送命令」のほかに、「その他の命令」に分 類される命令も含まれます。

● 制御転送命令の種類 制御転送命令は、プログラムの実行を制御するための命令で

#### 〔表 1〕x86 系 32 ビット CPU のプログラム実行制御に関する命令

| 分 類    | インストラ          | 動作                                                                                                                                                       | 影響を受けるフラグ |                  |         |     | *  |    |
|--------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|------------------|---------|-----|----|----|
| 23 AR  | クション名          | 29/4 [[                                                                                                                                                  |           | SF               | ZF      | AF  | PF | CF |
|        | JMP            | Jump<br>指定されたアドレスに無条件でプログラムの制御を移す                                                                                                                        |           |                  |         |     |    |    |
|        | Jcc            | Jump if Condition Is Met<br>条件 cc が成立していれば指定されたアドレスにプログラム<br>の制御を移す                                                                                      |           |                  | ٠       |     |    |    |
|        | LOOP<br>LOOPcc | Loop with (E) CX counter<br>レジスタ(E) CX を - 1 し、ゼロでなければ指定されたアドレス<br>にプログラムの制御を移す.条件 cc が指定されていた場合は、<br>上記の条件の他に指定条件 cc も成立していれば、指定された<br>アドレスにプログラムの制御を移す |           |                  | ٠       |     | ٠  | •  |
| 制      | CALL           | Call Procedure<br>リターンアドレスをスタックに PUSH し、指定されたアドレ<br>スに無条件でプログラムの制御を移す                                                                                    |           |                  |         |     |    |    |
| 御転送    | RET            | Return from Procedure<br>スタックからリターンアドレスを POP し,そのリターンアドレ<br>スに無条件でプログラムの制御を移す                                                                            |           |                  |         |     |    |    |
| 命<br>令 | INT            | Software Interrupt<br>ソフトウェア割り込みを発生させる                                                                                                                   |           |                  |         |     | •  |    |
|        | INTO           | Software Interrupt on overflow<br>OF=1 なら4番のソフトウェア割り込みを発生させる                                                                                             | IF        | - <sub>0</sub> , | TF -    | - 0 | •  | •  |
|        | BOUND          | Check Array Index Against Bounds<br>配列インデックスが上下限を超えていないかどうか調べ,<br>範囲外なら5番のソフトウェア割り込みを発生させる                                                               |           |                  |         |     |    |    |
|        | IRET           | Interrupt Return<br>割り込み処理ルーチンから通常のルーチンに戻る                                                                                                               | *<br>IF   | *<br>- *,        | *<br>TF | *   | *  | *  |
|        | ENTER          | Make Stack Frame for Procedure Parameters<br>高級言語のためのスタックフレームを作成する                                                                                       |           |                  |         |     |    |    |
|        | LEAVE          | High Level Procedure Exit<br>ENTER 命令で作成したスタックフレームを削除する                                                                                                  |           |                  | •       |     |    |    |
| その他    | NOP            | No Operation<br>何の操作もしない命令                                                                                                                               |           |                  |         | •   |    |    |
| の命令    | UD2            | Undefined Instruction<br>無効オペランドの例外(割り込み番号6)を発生させる命令                                                                                                     |           |                  |         |     |    |    |

注:表中の影響を受けるフラグ の記号は次の状態を表す

=変化なし

\*=結果にしたがって変化する

0=クリアされる



- す. この命令には、
- (1) 指定アドレスに無条件で移行する「無条件ジャンプ」
- (2) CPU が指定の状態にあるとき、指定したアドレスに移行する「条件付きジャンプ」
- (3) 指定回数プログラムの同じ部分を繰り返し実行する「ループ」
- (4) サブルーチンを呼び出すための「コール」とサブルーチンか ら元のルーチンに戻るための「リターン」
- (5) ソフトウェア割り込みおよび例外を発生させる命令と割り 込み例外からのリターン命令
- (6) サブルーチンのためのスタックフレームの作成と解放 の6種類があります.

(1)  $\sim$  (5) は移行命令なので、CPU のレジスタ EIP の書き換えを行います。しかし(6) の命令は、サブルーチンで使われるスタックフレームの操作なので、レジスタ ESP と EBP が操作対象になり、レジスタ EIP の変更はありません。

「その他の命令」に分類されている命令

「その他の命令」の中で実行に関する命令としては、NOP命令とUD2命令の2命令があります。

NOP命令は、"No Operation"の略で、その名が示すように、NOP命令を実行しても CPU は何の操作も行いません。NOP命令自体はオペランドがなく、オペコードが gohの1バイト長の命令です。そのため、この NOP命令を実行してもレジスタ EIPが+1されるだけで、すべてのフラグ、レジスタ、メモリ、I/O に影響を与えません。

UD2 命令は、"Undefined Instruction"といい、無効オペコードの例外を発生させます。UD2 命令にもオペランドはありません。この UD2 命令は、無効オペコードの例外(割り込み番号6)を発生する以外は、NOP 命令と同じで CPU に何の影響も与えません。UD2 命令の用途は、無効オペコードの例外を処理するハンドラをデバッグするときに使用するもので、通常の多くのプログラムでは、この UD2 命令を使いません。そのため、この連載で使用しているアセンブラ MASM も gas も、この UD2 命令はサポートしていません。

### ジャンプ命令 (JMP, Jcc)

ジャンプ命令のニモニックは、無条件ジャンプ命令の場合は「JMP」です.状態付きジャンプ命令の場合は、表2に示す条件を表す文字をccとすると、頭にJを付けて「Jcc」と記述します.

JMP 命令は、無条件に指定された飛び先の命令にジャンプします。JMP 命令には、飛び先のアドレスの違いから、同じ物理セグメント内なら「near ジャンプ」、異なる物理セグメントなら「far ジャンプ」を使うことになります。また、near ジャンプはさらにアドレスの指定方法の違いから「相対オフセット」、「絶対オフセット」の2種類に分けられます。

Jec命令は、ccで指定された条件( $\mathbf{表 2}$ )が成立した場合のみ、

#### 〔表 2〕Jcc 命令のニモニックで使われる条件を表す文字

| 文字   | 内容                                   | 成立となる条件                         |
|------|--------------------------------------|---------------------------------|
|      | レジスタ CX がゼロ                          | ス. とこ る 3 米 II                  |
| CXZ  | (short ジャンプのみ使用可能)                   | CX=0                            |
|      | レジスタ ECX がゼロ                         | Torr o                          |
| ECXZ | (short ジャンプのみ使用可能)                   | ECX=0                           |
| E    | Equal等しい                             | ZF=1                            |
| Z    | Zeroゼロ                               | ZF=1                            |
| NE   | Not Equal等しくない                       | ZF=0                            |
| NZ   | Not Zeroゼロではない                       | ZF=0                            |
| A    | Aboveより上                             | CF=0 and $ZF=0$                 |
| NBE  | Not Below or Equal<br>より下でなく等しくない    | CF=0 and ZF=0                   |
| AE   | Above or Equalより上か等しい                | CF=0                            |
| NB   | Not Belowより下でない                      | CF=0                            |
| В    | Belowより下                             | CF=1                            |
| NAE  | Not Above or Equal<br>より上でなく等しくない    | CF=1                            |
| BE   | Below or Equalより下か等しい                | CF=1 or ZF=1                    |
| NA   | Not Aboveより上でない                      | CF=1 or ZF=1                    |
| G    | Greaterより大きい                         | ZF=0 and SF=OF                  |
| NLE  | Not Less or Equal<br>より小さくなく等しくない    | ZF=0 and SF=OF                  |
| GE   | Greater or Equal<br>より大きいか等しい        | SF=OF                           |
| NL   | Not Lessより小さくない                      | SF=OF                           |
| L    | Lessより小さい                            | SF ≠ OF                         |
| NGE  | Not Greater or Equal<br>より大きくなく等しくない | SF ≠ OF                         |
| LE   | Less or Equal<br>より小さいか等しい           | ZF=1 or SF ≠ OF                 |
| NG   | Not Greaterより大きくない                   | $z_{F=1}$ or $s_{F} \neq o_{F}$ |
| C    | Carryキャリーがある                         | CF=1                            |
| NC   | Not Carryキャリーがない                     | CF=0                            |
| 0    | Overflowオーバフローがある                    | OF=1                            |
| NO   | Not Overflowオーバフローがない                | OF=0                            |
| S    | Sign  符号がある(負数)                      | SF=1                            |
| NS   | Not Sign符号がない(非負数)                   | SF=0                            |
| P    | Parityパリティがある                        | PF=1                            |
| PE   | Parity Evenパリティが偶数                   | PF=1                            |
| NP   | Not Parityパリティがない                    | PF=0                            |
| PO   | Parity Oddパリティが奇数                    | PF=0                            |

指定された飛び先の命令にジャンプします. 飛び先のアドレスは、同じ物理セグメント内のみで「相対オフセット」で指定します.

● 相対オフセットによる near ジャンプ

相対オフセットとは、アドレス上、JMP/Jcc 命令の次に配置 された命令の先頭アドレスをゼロと考え、飛び先の命令までの バイト数を指定するものです(**図1**).

そのため、相対オフセットの値は符号付き整数となります。 ジャンプのときは、

レジスタ EIP ←ジャンプ命令の次の命令のオフセット

+相対オフセット

という計算を行ってジャンプします。このとき、プログラムが 16 ビットプログラムで実行していた場合、レジスタ EIP には「ジャンプ命令の次の命令のオフセット+相対オフセット」の下位

#### 〔図1〕相対オフセット

#### ジャンプ命令の次の命令の第1バイト が相対オフセットのゼロとなる



- ▶ ジャンプ命令Xから命令Aにジャンプする場合の相対オフセットは、 (ジャンプ先の命令Aの第1バイトのオフセット) - (ジャンプ命令Xの次の命令Zの第1バイトのオフセット) となり、命令Bにジャンプする場合の相対オフセットは、 (ジャンプ先の命令Bの第1バイトのオフセット) - (ジャンプ命令Xの次の命令Zの第1バイトのオフセット) となる
- ▶ たとえば、上図A、X、Z、Bがセグメント上で次のアドレスにある場合の相対オフセットは下図のようになる



ワード(レジスタ IP)のみにジャンプ先オフセットがロードされ、 上位ワードはゼロになります。

相対オフセットの値は、機械語命令の中にその値が埋め込まれます。相対オフセットによる near ジャンプでは、セグメント内全域をジャンプ対象とする「相対 near ジャンプ」と、ごく限られた範囲をジャンプ対象とする「相対 short ジャンプ」の 2 種類があります。

また、とくにごく限られた範囲をジャンプ対象とするジャンプ命令のことを単に「short ジャンプ」といい、区別しています。short ジャンプは、相対オフセットの値が1バイトの範囲(-128~+127)と決められています。そのため、short ジャンプはジャンプできる範囲は狭いものの、機械語命令の長さで比べた場合、もちろん short ジャンプのほうが、セグメント内全域をジャンプ対象とした相対オフセットのnear ジャンプより短くなります。

Jcc 命令のうち、JCXZ、JECXZ 命令は、short ジャンプしかありません。そのため、JCXZ、JECXZ 命令のみ相対オフセットが $-128 \sim +127$  の範囲内でのジャンプとなります。

#### 〔図 2〕絶対オフセット



▶ たとえば、nearポインタが4CF3hなら、ジャンプ命令Xは同じセグメント 上にあるオフセット4CF3hが第1バイトの命令Cにジャンプする アセンブラ MASM も gas も、飛び先である命令までのバイト数の違いにより、short ジャンプにするか否かを自動的に判断して、機械語命令を生成するため、プログラミングの段階では、この short ジャンプにするか否かの違いは、あまり考える必要はありません。ただし、今述べたように JCXZ、JECXZ 命令は short ジャンプしかないため、この JCXZ、JECXZ 命令のみ、飛び先の命令までのバイト数には、注意する必要があります。

#### ● 絶対オフセットによる near ジャンプ

絶対オフセットによる near ジャンプは、レジスタあるいはメモリ上にある飛び先のアドレス (オフセットのみ)を使用してジャンプするものです。これを「絶対間接 near ジャンプ」と呼びます。

飛び先のアドレスは、オフセットのみなので near ポインタとして指定します。そのため、16 ビットプログラムでは 16 ビットの near ポインタ、32 ビットプログラムでは 32 ビットの near ポインタを使います。ジャンプのときは、この near ポインタの値がそのままレジスタ EIP にロードされます。このとき、16 ビット near ポインタだった場合、レジスタ EIP の上位ワードにはゼロが入り、レジスタ EIP の下位ワード(レジスタ IP)に 16 ビット near ポインタがロードされます(図 2)。

現在使われている Windows や Linux のプログラムは、すべて 32 ビットのプログラムなので、Windows や Linux のプログラム では 32 ビット near ポインタを使うことになります.

#### ● far ジャンプ

JMP 命令は、far ポインタで飛び先を指定することで、異なる物理セグメントへジャンプすることができます.

far ジャンプでは、レジスタ(E) IP のほかに、セグメントレジスタ CS も更新されます。far ポインタは、機械語命令に直接埋

#### 〔リスト 1〕MASM の NOP、JMP、Jcc、LOOP 命令の記述例



め込む「絶対 far ジャンプ」と、メモリで指定する「絶対間接 far ジャンプ」があります。また、この far ポインタによるジャンプは、セグメント外ジャンプのほかに、異なるタスクへの移行や特権レベルの異なるルーチンへのジャンプなどに使用されます。

本連載の第 13 回 (2002 年 12 月号) の最初でも述べたように、Windows や Linux の 32 ビットプログラムは、一つ大きなセグメントにコードもデータ (スタックを含む) も一緒にロードするため、一般の Windows や Linux のプログラムでは、セグメント外ジャンプはありません。

また、異なるタスクへの移行や特権レベルの異なるルーチンへのジャンプといったことは、OS やライブラリが行ってくれるため、一般のアプリケーションプログラムでは、この far ポインタによるジャンプは通常では使用することはありません。

● 実際の MASM および gas でのジャンプ命令の記述例 リスト1が、実際の MASM でのジャンプ命令(JMP, Jcc)の 記述例を示したものです。そしてリスト2に実際の gas での ジャンプ命令(JMP, Jcc)の記述例を示しています。

**リスト 1**, **リスト 2** とも, 通常 Windows や Linux の 32 ビット

#### 〔リスト 2〕gas の NOP, JMP, Jcc, LOOP 命令の記述例



プログラムでは使用されることがない far ジャンプについては割 愛しました. そのため, リスト1, リスト2では, 使用されるこ とが多い near ジャンプのみを示しました。

### ループ命令(LOOP, LOOPcc)

ループ命令のニモニックは、単純なループの命令が「LOOP」 状態付きのループ命令が「LOOPcc | です。

LOOPcc の cc の部分には「Z」, 「E」, 「NZ」, 「NE」の条件を表す 文字が入ります。条件「Z |、「E |、「NZ |、「NE | の意味は、**表 1** の Jcc と同じです。機械語命令的には LOOPZ と LOOPE は同じコー ドで、LOOPNZ と LOOPNE も同じコードとなっています。

ループ命令での飛び先のアドレスは、同じ物理セグメント内 のみの「相対オフセット」で指定します。ただし、ループ命令に は short ジャンプしかないため、相対オフセットの値は-128~+127の範囲を超えないようにする必要があります.

ループ命令は、ループ回数を数えるカウンタとして、レジスタ CX あるいはレジスタ ECX を使用します. LOOP 命令では、まず レジスタ(E) CX がデクリメント(-1) されます。その結果、レジ スタ(E) CX がゼロでなければ、指定アドレスの命令にジャンプ します. しかし、レジスタ(E) CX がゼロだった場合は、プログラ ムの順番どおりに LOOP 命令の次の命令を実行します〔図3(a)〕.

LOOPcc 命令の場合は、レジスタ(E)CX がゼロか否か調べら れるところで、条件 cc も調べられます [図 3(b)].

つまり、LOOPZ および LOOPE は、レジスタ(E) CX ≠ 0 でかつ ZF = 1(ゼロあるいは等しい)ならジャンプします。逆に、レジ  $Z_{F}(E) = 0$  あるいは  $Z_{F} = 0$  なら次の命令を実行します。ま た、LOOPNZおよびLOOPNEは、レジスタ(E)CX ≠ 0 でかつ ZF = 0(ゼロでないあるいは等しくない)ならジャンプします. 逆に、レジスタ(E) CX = 0 あるいは ZF = 1 なら次の命令を実行 します.

リスト1が実際のMASMでのループ命令の記述例,リスト2 が gas でのループ命令の記述例です。

### コール命令(CALL)

サブルーチンを呼び出す場合には CALL を使用します。CALL 命令は, 無条件コールのみです。

CALL 命令には、呼び出し先のアドレスの違いから、同じ物理 セグメント内なら「near コール」, 異なる物理セグメントなら「far コール」を使うことになります。また、near コールはさらにアド レスの指定方法の違いから「相対オフセット」、「絶対オフセット」 の2種類があります.

#### ● 相対オフセットによる near コール

JMP 命令で使われる相対オフセットと同じです。 ただし, CALL 命令には short タイプのコールはありません. セグメント 内の全域をコール対象とした、相対オフセットの near コール

#### 〔図3〕LOOP、LOOPcc 命令の動作



(b) LOOPcc命令

(相対 near コール) のみが使用できます.

#### ● 絶対オフセットによる near コール

JMP 命令で使われる絶対オフセットと同じで、レジスタある いはメモリ上にある呼び出し先のオフセット(near ポインタ)を 使用してサブルーチンをコールするものです(絶対間接 near コ ール)

#### far コール

JMP 命令と同じように、far ポインタで呼び出し先を指定する ことで、異なる物理セグメントのサブルーチンをコールすること ができます.

far コールでは、レジスタ(E) IP の他に、セグメントレジスタ CS も更新されます. far コールで使われる far ポインタは、機械 語命令に直接埋め込まれた「絶対 far コール」と、メモリで指定 する「絶対間接 far コール」があります。また、この far ポインタ によるコールは、セグメント外のサブルーチン呼び出しのほか に、異なるタスクにあるルーチンの呼び出しや特権レベルの異 なるルーチンの呼び出しなどに使用されます.

JMP 命令のところでも述べたように、Windows や Linux の 32 ビットプログラムでは、一つ大きなセグメントにコードもデータ (スタックを含む)も一緒にロードするため、一般の Windows や Linux のアプリケーションプログラムでは、セグメント外コール は使用しません。

また、異なるタスクにあるルーチンの呼び出しや特権レベル の異なるルーチンの呼び出しといったことは、OS やライブラリ が行ってくれるため、このfar ポインタによる呼び出しは通常使 用することはありません.

#### ● CALL 命令の動作

CALL 命令は、指定アドレスにジャンプする前に、サブルーチ ンから戻ってくるためのリターンアドレスをスタックに PUSH し た後、呼び出し先のアドレスをレジスタ(E) IP(far コールなら

#### 〔図4〕CALL命令の動作



① nearコールの場合

- リターンアドレスとしてスタックには b+(CALL命令のバイト数) onearポインタが入る
- レジスタ(E)IPはオペランドで指定された命令のオフセットBに更新される.
   CSはaのまま変わらない(A=a)

② farコールなら

- リターンアドレスとしてスタックには オフセット=b+(CALL命令のバイト数) セレクタ=a
- がfarポインタとして入る
- レジスタ(E)IPはオペランドで指定された命令の オフセットBに変更され、CSもAに変更される

cs も) に設定します(図4).

スタックに PUSH されるリターンアドレスは, セグメント内呼び出しなら near ポインタが使われ, プログラムの実行モードが 16 ビットなら 16 ビットの near ポインタ, 32 ビットなら 32 ビットの near ポインタが使われます. また, セグメント外呼び出しなら far ポインタがリターンアドレスとしてスタックに PUSH されます. この場合も, プログラムの実行モードにより, 16 ビットなら 32 ビットの far ポインタが使われます.

リスト3が MASM での CALL 命令の記述例, リスト4が gas での CALL 命令の記述例です. リ スト3, リスト4とも通常の Windows や Linux の32 ビットプログラムでは使用されることがない far コールについては割愛しました. そのため, リ スト3, リスト4では, 使用されることが多い near コールのみを示しました.

〔リスト 3〕 MASM の CALL, RET, INT, IRET, BOUND, ENTER, LEAVE 命令の記述例



### リターン命令(RET)

RET 命令は、CALL 命令に対応する形で、near コールされたサブルーチンからの戻り「near リターン」と、far コールされたサブルーチンからの戻り「far リターン |  $0^-$ つの命令をもっています。

#### ● リターン命令の動作

near リターンでは、スタックに保存されている near ポインタ のリターンアドレスをスタックから POP し、レジスタ (E) IP に ロードすることで、サブルーチンを呼び出した元のルーチンへ戻ります。

far リターンでは、スタックに保存されている far ポインタの リターンアドレスをスタックから POP し、レジスタ (E) IP およ びセグメントレジスタ CS にロードすることで、サブルーチンを 呼び出した元のルーチンへ戻ります。また、CALL 命令で特権レ ベルの異なるルーチンを呼び出した場合、RET 命令により元の 特権レベルのルーチンに戻ることができます。

先に述べたように、Windows や Linux の 32 ビットプログラムでは、セグメント外コールや特権レベルの異なるルーチンの呼び出しといったことは、一般的なアプリケーションプログラムでは行わないため、RET 命令でもこのような far リターンは通常使用されません。

#### リターン命令のオペランド

RET 命令には、near/far の両方のリターンに、16 ビットイミディエイトのオペランド付きとなしの二つの命令があります。オ

ペランドなしのリターン命令は、今説明した動作のみを行います. オペランド付きの RET 命令は、上記で説明した動作のほかに、 リターンアドレスをスタックから POP した後、オペランドで指 定された 16 ビットイミディエイトの値をレジスタ(E) SP に加算 します(図5). この 16 ビットイミディエイトのレジスタ(E) SP への加算というのは、サブルーチンを呼び出すときスタックに 積まれた実引き数を削除するのに使用します.

リスト 3 が MASM での RET 命令の記述例, リスト 4 が gas での RET 命令の記述例です. リスト 3, リスト 4 ともに, 通常は Windows や Linux の 32 ビットプログラムでは使用されることがない far リターンについては割愛しました. そのため, リスト 3, リスト 4 では, 使用されることの多い near リターンのみを示しました.

### 割り込み(例外)を発生させる命令 (INT, INT 3, INTO, BOUND)と 割り込み(例外)からのリターン命令(IRET)

INT命令、INT 3命令、INTO命令、BOUND命令は、プログラムでソフトウェア割り込みや例外を発生させるための命令です。 そして、IRET命令がハードウェア割り込み、ソフトウェア割り込み、例外の処理ルーチン(ハンドラ)からのリターンとなります。

INT 命令のようなソフトウェア割り込みや例外、ハードウェア割り込みが発生するとスタックには、レジスタ(E) FLAGS の値とリターン先となる CS、(E) IP の値が**図 6** のように PUSH されます。

〔リスト 4〕gas の CALL,RET,INT,IRET,BOUND,ENTER,LEAVE 命令の記述例



#### 〔図5〕RET命令の動作



#### ● INT 命令, INT 3 命令

INT 命令は、8 ビットイミディエイトのオペランドで指定された番号  $(0 \sim 255)$  のソフトウェア割り込みを発生させます。また、INT 3 命令は、割り込み番号 3 のソフトウェア割り込みを発生させる命令です。通常 INT 命令は 2 バイト長なのですが、この INT 3 命令のみ 1 バイト長となっています。

この INT 3 命令は特別に用意された命令で、デバッガのブレークポインタとして使用するためのものです。そのため、命令長が1バイトになっています。

#### ● INTO 命令

INTO 命令は、ステータスフラグのオーバフローフラグ (OF) が1になっていたとき、割り込み番号 4 の例外を発生させる命令です。x86 系 CPU は、演算でオーバフローした場合でも例外は発生せず、ステータスフラグが OF = 1 となるだけです。そのため、オーバフローを例外で処理したい場合に、この INTO 命令を使用します。ですから、オーバフローに対する例外処理が用意されている場合のみ、この INTO 命令は使用できます。

#### 〔図 6〕 INT, INT 3, INTO, BOUND 命令, そして IRET 命令を実行した ときのスタック



#### ● BOUND 命令

BOUND 命令は、指定された配列のインデックスが有効範囲にあるか否かを調べるための命令です。インデックスはレジスタ、範囲指定の値はメモリに配置(最初の値が下限、次の値が上限)し、その値はともに 16 あるいは 32 ビットの符号付き整数で指定します。

もし、BOUND 命令でインデックスが範囲外と判断されたら、割り込み番号 5 の例外が発生します。ただし、この BOUND 命令は、INT、INT 3、INTO 命令とは異なり、リターンアドレスは例外を発生させた次の命令ではなく、BOUND 命令自体を指しているので、この点に注意が必要です。

この BOUND 命令も、例外処理が用意されている場合にのみ使用できる命令です。

#### ● IRET 命令

IRET 命令は、ハードウェア割り込みや例外、ソフトウェア割り込みの処理ルーチン(ハンドラ)からリターンするための専用の命令です。割り込みや例外が発生するとリターンアドレスに先立ち、レジスタ(E)FLAGS の値もスタックに PUSH されているので、通常の far リターンによる RET 命令は使用できません。そのため、割り込みや例外の処理からのリターンは、専用の IRET命令を使用します。IRET 命令を実行すると、スタックは図6のように割り込み前の状態に戻ります。

Windows や Linux ではこれらの命令は使用できない

Windows や Linux では、割り込みや例外のすべてを OS が管理しているため、一般のアプリケーションプログラムやドライバでは、勝手には割り込みや例外処理ルーチンを作ることはできません。そのため、ここで説明した割り込みや例外を発生させる命令は、アプリケーションなどのプログラムで使用することはありません。

また、Windows や Linux ではドライバ上の割り込み処理ルーチン(ハンドラ)も、割り込みのエントリとリターンを OS が管理 するため、ドライバ上でこの IRET 命令を使用することもありません.

#### 〔図7〕ENTER命令、LEAVE命令の動作





△=ENTER命令で生成され, LEAVEで 消去されるスタックフレーム

### スタックフレームの作成と解放を行う命令 (ENTER, LEAVE)

ENTER 命令は、高級言語で使われるスタックフレームを作成します。そして、ENTER 命令で作成したスタックフレームをLEAVE 命令で解放します。そのため、ENTER 命令はサブルーチンの最初で実行され、LEAVE 命令はサブルーチンの最後のRET命令の直前に実行されます。

ENTER 命令は二つのオペランドをもち、LEAVE 命令にはオペランドがありません。ENTER 命令の二つのオペランドは、ともにイミディエイトで、インテル表記で表すと、

ENTER imm16, imm8 となります.

最初の imm16 は、スタック上に確保するローカルな変数のための領域のバイトサイズです。このスタック上に確保されるローカルな変数とは、サブルーチン(手続きや関数)内でのみ使用され、サブルーチンから戻るとき消滅する変数のことです。C言語でいう auto 記憶クラスの変数に相当します。

次のimm8は、ネスティングレベルを示すもので $0 \sim 31$ のレベルを持ちます。このネスティングレベルは、PASCAL言語の

ような手続きの中に、さらにいくつもの手続きを入れ子(ネスト)の状態で記述できる言語で使用されます。この ENTER 命令の動作を図で表したのが図7です。

通常、アセンブラのプログラムでは、このような複雑な構造をしたサブルーチンは作成しません。つまり、ENTER命令は、CやPASCALなどのコンパイラが生成するオブジェクトとして使用されることを目的とした機械語命令だといえます。

LEAVE 命令は、ENTER 命令の作用を打ち消す動作として、

MOV (E)SP, (E)BP POP (E)BP

の2命令に相当する動作をします. LEAVE 命令自体は1バイトの命令であるため、この2命令を使う場面で、代わりに LEAVE 命令を使うことでプログラムを短くすることができます.

\* \*

次回は、x86系 CPU の汎用命令の内、最後に残ったストリング命令の詳細と、CPU 自体を制御するためのシステム命令の概略について説明する予定です。

おおぬき・ひろゆき 大貫ソフトウェア設計事務所

# Universal Plug and Playの全貌 ▶ ▶ ▶ ▶

# #2回 UPnP の規格概要(後編)

茶間 康

従来、ネットワーク機器を接続するためには、IPアドレスの設定や各種デバイスドライバのインストールなど、煩雑な設定が必要だった。これを解決する手段として提案されたのがUniversal Plug and Play である。UPnPにより、ネットワーク機器を Plug and Play 感覚で使用することが可能になる。そして、その適応範囲はルータなどの純然たるネットワーク機器だけでなく、プリンタ、スキャナ、デジカメ、AV機器など、幅広い。また基盤技術として、SOAP (Simple Object Access Protocol) と XMLを使用しているため、理解が容易である。

そこで本稿では、注目度が高まる UPnP について連載で解説し、その理解を深める。第1回と第2回 (今回)では UPnP の規格について解説を行い、第3回では実際の UPnP プログラミングを解説する。

(編集部)



第1回ではアドレッシング、ディスカバリ、ディスクリプションを説明しました。これでデバイスが何者で、どのような機能(サービス)をもっているかと、それを判別するしくみまでが理解できたと思います。

今回は、実際にデバイスを制御する方法であるコントロールと、それに付随するイベンティング、プレゼンテーションを解説します。

### コントロール トトトトトトトトト

コントロールは、UPnPネットワークにおいてステップ3になります。コントロールは文字どおりコントロールポイントがデバイスを制御することですが、実際にはサービスに対して要求を行います。つまりデバイスは、サービスのためのコンテナといえます。では、コントロールポイントはサービスに関してどのようなことができるのでしょうか?

- 1) アクションを実行すること(アクションの実行)
- 2) アクションの結果を得ること(アクションのレスポンス)
- 3) サービスのもっている変数の値を調べること(クエリの実行)

#### 〔図1〕コントロールの動作



4) クエリの結果を得ること(クエリのレスポンス)

では、コントロールポイントがどのようにサービスに対して要求を行うかを説明します。ここでサービスディスクリプション(以降 SerDesc と記述)を思い出してください。コントロールのための URL があったと思います。ここへコントロールのためのメッセージを送ります。このメッセージに関しては後に説明します。デバイスは、ソース IP アドレスおよびポートにレスポンスメッセージを送信します。図1にコントロールの動作を示します。

UPnPのコントロールは、リモートプロシージャコール(RPC) 技術の一つである SOAP を使用します。SOAP はリモートプロシージャコールを実現するため、XML/HTTP の使用に関して定義しています。コントロールメッセージは、SOAP ヘッダおよびボディエレメントをベースにフォーマットされ、HTTP を介して TCP/IP により配信されます。また、デバイスは結果またはエラーを SOAP でカプセル化し、HTTP リクエストを介して送信します。コントロールポイントは、HTTP レスポンスを介して受信します。図 2 にコントロールで使用するプロトコルを示します。

#### ● アクションの実行

SOAPは、追加のHTTPへッダを定義しています。これらが HTTP拡張子と混同されないよう、HTTP Extension Framework にしたがって、MANへッダに SOAP 独自の URI お

〔図 2〕 コントロールにおいて 使用するプロトコル

| UPnPベンダ         |
|-----------------|
| UPnP Forum      |
| UPnPデバイスアーキテクチャ |
| SOAP            |
| HTTP            |
| ТСР             |
| ΙP              |
|                 |

#### (表1) コントロールメッセージ(POST)

POST path of control URL HTTP/1.1 HOST: host of control URL:port of control URL CONTENT-LENGTH: bytes in body CONTENT-TYPE: text/xml; charset="utf-8" SOAPACTION: "urn:schemas-upnp-org:service:serviceType:v#actionName" <s:Envelope xmlns:s="http://schemas.xmlsoap.org/soap/envelope/" s:encodingStyle="http://schemas.xmlsoap.org/soap/encoding/"> <s:Body> <u:actionName xmlns:u="urn:schemas-upnp-org:service:serviceType:v"> <argumentName>in arg value</argumentName> other in args and their values go here, if any </u:actionName> </s:Body> </s:Envelope> リクエストライン HTTPにより定義されたメソッド path control URL このサービスのコントロールのためのURLのパスコンポーネント(デバイスディスクリプションの サービスエレメントの controlURL サブエレメント). 単一の相対 URL HTTP/1.1 HTTPバージョン ヘッダ 必須項目.このサービスのコントロールのための URL のドメイン名または IP アドレスおよび任意のポートコンポーネント HOST (デバイス記述のサービスエレメントの controlURL サブエレメント).ポートが空,あるいは明記されていない場合は,80 が用いられる ACCEPT-LANGUAGE (コントロールメッセージでは ACCEPT-LANGUAGE ヘッダは使用されない) CONTENT-LENGTH 必須項目、バイト単位で示したボディの長さ、整数 CONTENT-TYPE 必須項目. text/xml でなくてはならない. 使用される文字コーディング(例: utf-8)を含む (メソッド POST によるリクエストには MAN ヘッダはない) MAN SOAPが定義する必須ヘッダ. サービスタイプ, ハッシュ文字, そして呼び出すアクションで, すべてダブルクォーテー SOAPACTION ションで括られる、メソッド M-POST によるリクエストで用いられる場合、ヘッダ名は MAN ヘッダで定義される HTTP ネ ームスペースにより許可されたものでなくてはならない。単一のURI ボディ SOAPが定義する必須エレメント. xmlnsの名前属性は,必ず http://schemas.xmlsoap.org/soap/envelope/ Envelope となる. また,必ず http://schemas.xmlsoap.org/soap/envelope/ "という値の encodingStyle 属性を含む. 以下のサブエレメントを含む SOAP が定義する必須エレメント、SOAP ネームスペースにより認可されたもの。以下のサブエレ Body メントを含む 必須項目.名前エレメントは呼び出すアクションの名前.xmlns ネームスペー actionName ス属性は、ダブルクォーテーションで括られたサービスタイプ、ボディの最初 のサブエレメントでなくてはならない. 以下の順序でサブエレメントを含む アクションに in 引き数がある場合のみ必須項目. アクションに渡される値. argumentName 各in引き数に対し1度繰り返す(ネームスペースにより認可されていないエレ メント名.エレメントネスト化コンテンツで充分). UPnP サービスディスク

よび接頭辞 M-のついた HTTP メソッドを指定します。この場合、メソッドは M-POST となります。M-POST を使用する場合、HTTP サーバが SOAP 独自の URI および SOAP 固有のヘッダを見つけ、理解する必要があります。ファイアウォールやプロキシが柔軟な管理をできるようにするために、SOAP ではリクエストするとき、最初に MAN ヘッダや M-接頭辞が必須となります。

リクエストが 05 Method Not Allowed "というレスポンスで拒否された場合には、次のリクエストは MAN ヘッダと M-接頭辞を用いて送信されます。そのリクエストが 01 Not Implemented "あるいは" 10 Not Extended "というレスポンスで拒否された場合、リクエストは失敗となります(他の

HTTPレスポンスは、HTTPの仕様にしたがって処理される). 以下に、POSTメソッド(MAN ヘッダなし)を用いて送信されるコントロールメッセージを**表 1**に示します。それに続いて、M-POSTメソッドおよび MAN ヘッダを用いて送信されるコントロールメッセージを**表 2**に示します。

#### アクションのレスポンス

リプションに定義される単一のデータ型

コントロールポイントからのアクションの実行要求に対して結果を返します。サービス(デバイス)はSOAPでカプセルし、HTTPリクエストを介して送信し、コントロールポイントはHTTPレスポンスを介して受信されます。サービスは、転送時間を含めアクションの実行とレスポンスを30秒以内に完了しなければなりません。これより長くかかるアクションは、すぐ

#### 〔表2〕コントロールメッセージ(M-POST)

M-POST path of control URL HTTP/1.1

HOST: host of control URL:port of control URL

CONTENT-LENGTH: bytes in body

CONTENT-TYPE: text/xml; charset="utf-8"

MAN: "http://schemas.xmlsoap.org/soap/envelope/"; ns=01

(メソッド M-POST のリクエストのメッセージボディは、メソッド POST のリクエストのボディと同様)

| リクエストライン        | リクエストライン                                                                                                                                                        |                                                                                           |  |  |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|--|--|
| M-POST          | HTTP Extension Framework により定義されたメソッド                                                                                                                           |                                                                                           |  |  |
|                 | path of control URL                                                                                                                                             | このサービスのコントロールのための URL のパスコンポーネント (デバイスディスクリプションのサービスエレメントの controlURL サブエレメント). 単一の相対 URL |  |  |
|                 | HTTP/1.1                                                                                                                                                        | HTTPバージョン                                                                                 |  |  |
| ヘッダ             |                                                                                                                                                                 |                                                                                           |  |  |
| HOST            | 必須項目. このサービスのコントロールのための URL のドメイン名または IP アドレスおよび任意のポートコンポーネント (デバイスディスクリプションのサービスエレメントの controlURL サブエレメント). ポートが空, あるいは明記されていない場合は 80 が用いられる                   |                                                                                           |  |  |
| ACCEPT-LANGUAGE | (コントロールメッセージではACCEPT-LANGUAGE ヘッダは使用されない)                                                                                                                       |                                                                                           |  |  |
| CONTENT-LENGTH  | 必須項目. バイト単位で示したボディの長さ. 整数                                                                                                                                       |                                                                                           |  |  |
| CONTENT-TYPE    | 必須項目. text/xml でな                                                                                                                                               | くてはならない. 使用される文字コーディング(例:utf-8)を含む                                                        |  |  |
| MAN             | 必須項目. 必ず http://schemas.xmlsoap.org/soap/envelope/ "となる. ns命令は,他のSOAPヘッダ(例:SOAPACTION)に対しネームスペース(例:01)を定義する                                                     |                                                                                           |  |  |
| SOAPACTION      | SOAPが定義する必須ヘッダ. サービスタイプ, ハッシュ文字, そして呼び出すアクションで, すべてダブルクォーテーションで括られる. メソッド M-POST によるリクエストで用いられる場合, ヘッダ名は MAN ヘッダで定義される HTTP ネームスペースにより許可されたものでなくてはならない. 単一の URI |                                                                                           |  |  |



実行が成功したときのアクションレスポンスメッセージを表3に示します。また、サービスが、コントロールポイントからのアクションを実行中にエラーが発生した場合のアクションレスポンスメッセージを表4(pp.167-168)に示します。なお、定義されたエラータイプ(errorCode および errorDescription)エレメントに対応する値を表5に示します。

#### ● クエリの実行

コントロールポイントがサービスへアクションを実行させることに加え、サービスへクエリメッセージを送信し、ステートバリアブル(状態変数)の値を調査することができます。一つのクエリメッセージで問い合わせることができるのは一つの状態変数のみです。複数の状態変数を問い合わせるためには、複数のクエリメッセージを送信する必要があります。コントロール

ポイントがステートバリアブル(状態変数)の値を問い合わせる ためのメッセージの形式を**表 6**(pp.168-169)に示します.

なお、POST メソッドによるリクエストが"05 Method Not Allowed "という応答で拒否された場合、すでにアクションの実行で説明したように、コントロールポイントは  $MAN \sim y$  を M-接頭辞を用いたリクエストを送信します。

#### クエリのレスポンス

コントロールポイントからのステートバリアブル(状態変数)値の問い合わせにレスポンスするため、サービスは転送時間を含めて30秒以内に応答しなければなりません。サービスがこの時間内に応答できなかった場合にコントロールポイントが行うべきことは、アプリケーションにより異なります。クエリが成功したときのクエリレスポンスメッセージを表7(p.169)に示します。サービスがコントロールポイントからのクエリを実行中にエラーが発生した場合のクエリレスポンスメッセージを表8(p.170)に示します。

#### 〔表 5〕コントロールのエラーコード

| errorCode | errorDescription | 記 述                                                                        |
|-----------|------------------|----------------------------------------------------------------------------|
| 401       | Invalid Action   | このサービスには指定された値のアクションは存在しない                                                 |
| 402       | Invalid Args     | 以下のいずれかである可能性がある:in引き数が不十分,in引き数が過剰,指定された名前のin引き数が存在しない,一つ以上のin引き数のデータ型が不正 |
| 403       | Out of Sync      | 同期していない                                                                    |
| 501       | Action Failed    | サービスの現在の状態によりそのアクションの呼び出しが不可能になっている可能性がある                                  |
| 600-699   | TBD              | 共通アクションエラー.UPnP Forum WC により定義                                             |
| 700-799   | TBD              | 標準アクションのアクション固有エラー. UPnP Forum WC により定義                                    |
| 800-899   | TBD              | 非標準アクションのアクション固有エラー. UPnPベンダにより定義                                          |

#### 〔表3〕**アクションレスポンスメッセージ**(サクセス)

```
HTTP/1.1 200 OK
CONTENT-LENGTH: bytes in body
CONTENT-TYPE: text/xml; charset="utf-8"
DATE: when response was generated
SERVER: OS/version UPnP/1.0 product/version
<s:Envelope
xmlns:s="http://schemas.xmlsoap.org/soap/envelope/"
 s:encodingStyle="http://schemas.xmlsoap.org/soap/encoding/">
   <u:actionNameResponse xmlns:u="urn:schemas-upnp-org:service:serviceType:v">
     <argumentName>out arg value</argumentName>
 other out args and their values go here, if any
   </u:actionNameResponse>
 </s:Body>
</s:Envelope>
リクエストライン
        HTTPバージョン
HTTP/1.1
        200 OK
               HTTPサクセスコード
ヘッダ
CONTENT - LANGUAGE
                (コントロールメッセージでは CONTENT-LANGUAGE ヘッダは使用されない)
                必須項目、バイト単位で示したボディの長さ、整数
CONTENT-LENGTH
CONTENT-TYPE
                必須項目. text/xml でなくてはならない. 使用される文字コーディング(例: utf-8)を含む
                      アクションのレスポンスメッセージが生成された日付を指定する. RFC 1123 で定義されている日付と時間
DATE
                コードで指定する
                必須項目、MAN ヘッダの値を理解したかどうかの確認(ヘッダのみ、値なし)
EXT
                必須項目. OS 名, OS バージョン, UPnP/1.0, 製品名および製品バージョンを連記したもの. 文字列
SERVER
ボディ
Envelope
        SOAPが定義する必須エレメント. xmlnsの名前属性は,必ず http://schemas.xmlsoap.org/soap/envelope/ "となる.
        また,必ず"http://schemas.xmlsoap.org/soap/envelope/"という値のencodingStyle属性を含む.以下のサブエレ
        メントを含む
                SOAP が定義する必須エレメント、SOAP ネームスペースにより認可されたもの、以下のサブエレメントを含む
        Body
                                必須項目. レスポンスされたアクションの名前. xmlns ネームスペース属性は, ダブル
                actionNameResponse
                                クォーテーションで括られたサービスタイプ.ボディの最初のサブエレメントでなくては
                                ならない、以下のサブエレメントを含む
                                            アクションに out 引き数がある場合のみ必須項目. アクションから返
                                argumentName
                                            される値、各out引き数に対し1度繰り返し、アクションがretval
                                            とマークされた引き数をもつ場合、この引き数が最初のエレメントと
                                            なる(ネームスペースにより認可されていないエレメント名. エレメン
                                            トネスト化コンテンツで充分). UPnPサービス記述に定義される単一
                                            のデータ型
```

#### 〔表 4〕 アクションレスポンスメッセージ(エラー)

```
HTTP/1.1 500 Internal Server Error
CONTENT-LENGTH: bytes in body
CONTENT-TYPE: text/xml: charset="utf-8"
DATE: when response was generated
EXT:
SERVER: OS/version UPnP/1.0 product/version
xmlns:s="http://schemas.xmlsoap.org/soap/envelope/"
 s:encodingStyle="http://schemas.xmlsoap.org/soap/encoding/">
 <s:Bodv>
    <s:Fault>
      <faultcode>s:Client</faultcode>
      <faultstring>UPnPError</faultstring>
      <detail>
        <UPnPError xmlns="urn:schemas-upnp-org:control-1-0">
          <errorCode>error code
          <errorDescription>error string</errorDescription>
        </UPnPError>
      </detail>
    </s:Fault>
```

### 〔表 **4**〕 **アクションレスポンスメッセージ**(エラー)(つづき)

| リクエストラ         |                |                         |                                                                   |                                        |                                 |                                                                         |  |
|----------------|----------------|-------------------------|-------------------------------------------------------------------|----------------------------------------|---------------------------------|-------------------------------------------------------------------------|--|
| HTTP/1.1       | /1.1 HTTPバージョン |                         |                                                                   |                                        |                                 |                                                                         |  |
|                | 500 I:         | nternal                 | Server Error                                                      | HTTPエラーコ                               | 1 — K                           |                                                                         |  |
| ヘッダ            |                |                         |                                                                   | •                                      |                                 |                                                                         |  |
| CONTENT-LA     | NGUAGE         | (コントロ                   | 1ールメッセージで                                                         | は CONTENT-LAN                          | IGUAGE ヘッダは使用され                 | ない)                                                                     |  |
| CONTENT-LE     | NGTH           | 必須項目                    | . バイト単位で示し                                                        | <sub>レ</sub> たボディの長さ                   | . 整数                            |                                                                         |  |
| CONTENT-TY     | PE             | 必須項目                    | . text/xml でなく                                                    | てはならない.                                | 使用される文字コーディン                    | ング(例:utf-8)を含む                                                          |  |
| DATE           |                |                         | 推奨項目、アクションのレスポンスメッセージが生成された日付を指定する。RFC 1123 で定義されている日付と時間コードで指定する |                                        |                                 |                                                                         |  |
| EXT            |                | 必須項目                    | 公須項目. MAN ヘッダが理解されたかどうかの確認 (ヘッダのみ、値なし)                            |                                        |                                 |                                                                         |  |
| SERVER         |                | 必須項目                    | . OS名, OSバーシ                                                      | ージョン,UPnP/1.0,製品名および製品バージョンを連記したもの.文字列 |                                 |                                                                         |  |
| ボディ            |                |                         |                                                                   |                                        |                                 |                                                                         |  |
| Envelope       | また,<br>メント     | 必ず" htt <u>r</u><br>を含む | o://schemas.xm                                                    | lsoap.org/soa                          | ip/envelope/ "という値              | emas.xmlsoap.org/soap/envelope/ "となる.<br>iの encodingStyle属性を含む. 以下のサブエレ |  |
|                | Body           |                         | SOAP が定義する必須エレメント、SOAP ネームスペースにより認可されたもの、以下のサブエレメントを含む            |                                        |                                 |                                                                         |  |
|                |                | Fault                   |                                                                   |                                        | アクション実行中にエラ<br>ブエレメントを含む        | ラーが発生したことを示す、SOAPネームスペース                                                |  |
|                |                |                         | faultcode                                                         |                                        | る必須エレメント. 値は<br>. Clientでなくてはなり | SOAP ネームスペースにより認可されたものでな<br>らない                                         |  |
|                |                |                         | faultstring                                                       | SOAPが定義す                               | る必須エレメント. UPnP                  | Errorでなくてはならない                                                          |  |
|                |                |                         | detail                                                            | SOAPが定義す                               | る必須エレメント                        |                                                                         |  |
| UPnPError UPnl |                | UPnP が定義する必須エ           | レメント                                                              |                                        |                                 |                                                                         |  |
|                |                |                         |                                                                   |                                        | errorCode                       | UPnPが定義する必須エレメント、どのエラーが発生したかを識別するコード、表参照、整数                             |  |
|                |                |                         |                                                                   |                                        | errorDescription                | UPnP が定義する推奨エレメント, 短い説明.<br>表5参照、文字列、256 文字未満であることが推<br>奨される            |  |

### 〔表 6〕ステートバリアブルの値を問い合わせるためのメッセージ

| (数の) スプート・・ファンルの間を向い合うともののアフェーン                     |                                                                                                                                          |                                                                                           |  |  |  |
|-----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|--|--|--|
| HOST: host of cor                                   | POST path of control URL:port of control URL HOST: host of control URL:port of control URL                                               |                                                                                           |  |  |  |
| CONTENT-LENGTH: h                                   |                                                                                                                                          |                                                                                           |  |  |  |
| CONTENT-TYPE: tex                                   | , .                                                                                                                                      |                                                                                           |  |  |  |
| SOAPACTION: "urn:                                   | schemas-upnp-org                                                                                                                         | :control-1-0#QueryStateVariable"                                                          |  |  |  |
| <s:envelope< td=""><td></td><td></td></s:envelope<> |                                                                                                                                          |                                                                                           |  |  |  |
| _                                                   | /aahomaa wmlaoan /                                                                                                                       | org/soap/envelope/"                                                                       |  |  |  |
|                                                     | -                                                                                                                                        | xmlsoap.org/soap/encoding/">                                                              |  |  |  |
| <s:body></s:body>                                   | - IICCD.//SCIICMAS.2                                                                                                                     | Amilboap.org/boap/chedding/                                                               |  |  |  |
| -                                                   | eVariable xmlns:u                                                                                                                        | ="urn:schemas-upnp-org:control-1-0">                                                      |  |  |  |
| _                                                   | variableName <td></td>                                                                                                                   |                                                                                           |  |  |  |
| <td>:eVariable&gt;</td> <td></td>                   | :eVariable>                                                                                                                              |                                                                                           |  |  |  |
|                                                     |                                                                                                                                          |                                                                                           |  |  |  |
| <s:envelope></s:envelope>                           |                                                                                                                                          |                                                                                           |  |  |  |
| リクエストライン                                            |                                                                                                                                          |                                                                                           |  |  |  |
| POST HTTP                                           | により定義されたメソ                                                                                                                               | " F                                                                                       |  |  |  |
| path                                                | of control URL                                                                                                                           | このサービスのコントロールのための URL のパスコンポーネント (デバイスディスクリプションのサービスエレメントの controlURL サブエレメント). 単一の相対 URL |  |  |  |
| HTTP/                                               | 1.1                                                                                                                                      | HTTPバージョン                                                                                 |  |  |  |
| ヘッダ                                                 |                                                                                                                                          |                                                                                           |  |  |  |
| HOST                                                | 必須項目. このサービスのコントロールのためのURLのドメイン名またはIPアドレスおよび任意のポートコンポート (デバイスディスクリプションのサービスエレメントの controlURL サブエレメント). ポートが空の場合, あるい記されていない場合, 80 が用いられる |                                                                                           |  |  |  |
| ACCEPT-LANGUAGE                                     | (コントロールメッセージでは ACCEPT-LANGUAGE ヘッダは使用されない)                                                                                               |                                                                                           |  |  |  |
| CONTENT-LENGTH                                      | 必須項目. バイト単位で示したボディの長さ. 整数                                                                                                                |                                                                                           |  |  |  |
| CONTENT-TYPE                                        | 必須項目. text/xml でなくてはならない. 使用される文字コーディング(例: utf-8)を含む                                                                                     |                                                                                           |  |  |  |
| MAN                                                 | (メソッド POST によるリクエストには MAN ヘッダはない)                                                                                                        |                                                                                           |  |  |  |

### 〔表 6〕ステートバリアブルの値を問い合わせるためのメッセージ(つづき)

| SOAPACTION | ない. メソッド M-POST |                              | 場合,ヘッダ名に              | -1-0#QueryStateVariable "でなくてはなら<br>はMAN ヘッダで定義される HTTP ネームスペー                                               |
|------------|-----------------|------------------------------|-----------------------|--------------------------------------------------------------------------------------------------------------|
| ボディ        |                 |                              |                       |                                                                                                              |
| Envelope   |                 | tp://schemas.xmlsoap.org     |                       | 'schemas.xmlsoap.org/soap/envelope/"<br>pe/"という値のencodingStyle属性を含む.                                         |
|            | Body            | SOAP が定義する必須エレメ<br>ブエレメントを含む | ント、SOAPネ・             | ームスペースにより認可されたもの. 以下のサ                                                                                       |
|            |                 | QueryStateVariable           | ームスペース<br>org:control | する必須エレメント. アクション名. xmlns ネス属性 は、必ず" urn:schemas-UPnP-<br>1-1-0"になる. Bodyの最初のサブエレメント<br>らない. 以下の順序でサブエレメントを含む |
|            |                 |                              | varName               | UPnP が定義する必須エレメント. 変数名                                                                                       |
|            |                 | QueryStateVariable           |                       | スにより認可されたもの、値は、問い合わせる<br>前となる、文字列                                                                            |

#### 〔表**7**〕**クエリレスポンスメッセージ**(サクセス)

| HTTP/1.1 2                                                                                                                                                                  | 200 OK                                  |                                                                       |                                                                                                                                 |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|-----------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 1 '                                                                                                                                                                         | CONTENT-LENGTH: bytes in body           |                                                                       |                                                                                                                                 |  |  |  |
| 1                                                                                                                                                                           | CONTENT-TYPE: text/xml; charset="utf-8" |                                                                       |                                                                                                                                 |  |  |  |
| 1                                                                                                                                                                           | DATE: when response was generated       |                                                                       |                                                                                                                                 |  |  |  |
| EXT:                                                                                                                                                                        | _                                       |                                                                       |                                                                                                                                 |  |  |  |
| SERVER: OS                                                                                                                                                                  | S/versio                                | n UPnP/1.0 product/version                                            |                                                                                                                                 |  |  |  |
| <s:envelop< td=""><td></td><td></td><td></td></s:envelop<>                                                                                                                  |                                         |                                                                       |                                                                                                                                 |  |  |  |
|                                                                                                                                                                             |                                         | schemas.xmlsoap.org/soap/envelope                                     |                                                                                                                                 |  |  |  |
| s:encodir                                                                                                                                                                   | -                                       | "http://schemas.xmlsoap.org/soap/                                     | encoding/">                                                                                                                     |  |  |  |
|                                                                                                                                                                             | _                                       | VariableResponse xmlns:u="urn:scho                                    | emas-upnp-org:control-1-0">                                                                                                     |  |  |  |
| 1                                                                                                                                                                           |                                         | eVariableResponse>                                                    |                                                                                                                                 |  |  |  |
| <td>-</td> <td>o variable verber</td> <td></td>                                                                                                                             | -                                       | o variable verber                                                     |                                                                                                                                 |  |  |  |
| <td></td> <td></td> <td></td>                                                                                                                                               |                                         |                                                                       |                                                                                                                                 |  |  |  |
| リクエストラ                                                                                                                                                                      | イン                                      |                                                                       |                                                                                                                                 |  |  |  |
| HTTP/1.1                                                                                                                                                                    | HTTP ×                                  | ージョン                                                                  |                                                                                                                                 |  |  |  |
|                                                                                                                                                                             | 200 OK                                  | HTTP サクセスコード                                                          |                                                                                                                                 |  |  |  |
| ヘッダ                                                                                                                                                                         |                                         |                                                                       |                                                                                                                                 |  |  |  |
| CONTENT-LANGUAGE (コントロールメッセージでは CONTENT-LANGUAGE ヘッダは使用されない)                                                                                                                |                                         |                                                                       |                                                                                                                                 |  |  |  |
| CONTENT-LE                                                                                                                                                                  | ENGTH                                   | 必須項目. バイト単位で示したボディの長さ. 整数                                             |                                                                                                                                 |  |  |  |
| CONTENT-TY                                                                                                                                                                  | /PE                                     | 必須項目. text/xml でなくてはならない. 使用される文字コーディング(例: utf-8)を含む                  |                                                                                                                                 |  |  |  |
| DATE                                                                                                                                                                        |                                         | 推奨項目. クエリのレスポンスメッセージが生成された日付を指定する. RFC 1123 で定義されている日付と時間コード<br>で指定する |                                                                                                                                 |  |  |  |
| EXT                                                                                                                                                                         |                                         | 必須項目. MAN ヘッダが理解されたかどうか                                               | 須項目. MAN ヘッダが理解されたかどうかの確認(ヘッダのみ. 値なし)                                                                                           |  |  |  |
| SERVER                                                                                                                                                                      |                                         | 必須項目. OS名, OSバージョン, UPnP/1.0, 製品名および製品バージョンを連記する. 文字列                 |                                                                                                                                 |  |  |  |
| ボディ                                                                                                                                                                         |                                         |                                                                       |                                                                                                                                 |  |  |  |
| Envelope SOAP が定義する必須エレメント. xmlnsの名前属性は、必ず http://schemas.xmlsoap.org/soap/envelope/ "とまた、必ず http://schemas.xmlsoap.org/soap/envelope/"という値のencodingStyle属性を含む. 以下のサブ、ントを含む |                                         |                                                                       |                                                                                                                                 |  |  |  |
| Body                                                                                                                                                                        |                                         | SOAP が定義する必須エレメント、SOAP ネームスペースにより認可されたもの。以下のサブエレメントを含む                |                                                                                                                                 |  |  |  |
|                                                                                                                                                                             |                                         |                                                                       | UPnP および SOAP が定義する必須エレメント. xmlns ネームスペース属性は必ず" urn:schemas-UPnP-org: control-1-0"になる. Body の最初のサブエレメントでなくてはならない. 以下のサブエレメントを含む |  |  |  |
|                                                                                                                                                                             |                                         |                                                                       | return UPnPが定義する必須エレメント.(ネームスペースにより認可されていないエレメント名. エレメントネスト化コンテンツで充分). 値は, リクエストの varName エレメントで指定された状態変数の現在の値                  |  |  |  |

#### 〔表8〕 クエリレスポンスメッセージ(エラー)

```
HTTP/1.1 500 Internal Server Error
CONTENT-LENGTH: bytes in body
CONTENT-TYPE: text/xml; charset="utf-8"
DATE: when response was generated
EXT.
SERVER: OS/version UPnP/1.0 product/version
<s:Envelope
xmlns:s="http://schemas.xmlsoap.org/soap/envelope/"
s:encodingStyle="http://schemas.xmlsoap.org/soap/encoding/">
 <s:Bodv>
   <s:Fault>
     <faultcode>s:Client</faultcode>
     <faultstring>UPnPError</faultstring>
      <UPnPError xmlns="urn:schemas-upnp-org:control-1-0">
        <errorCode>error code
        <errorDescription>error string</errorDescription>
     </detail>
   </s:Fault>
 </s:Body>
</s:Envelope>
リクエストライン
        HTTPバージョン
HTTP/1 1
                                   HTTPエラーコード
         500 Internal Server Error
ヘッダ
              (コントロールメッセージでは CONTENT-LANGUAGE ヘッダは使用されない)
CONTENT-LANGUAGE
              必須項目。バイト単位で示したボディの長さ、整数
CONTENT-LENGTH
CONTENT-TYPE
              必須項目. text/xml でなくてはならない. 使用される文字コーディング(例: utf-8)を含む
              推奨項目. クエリのレスポンスメッセージが生成された日付を指定する. RFC 1123 で定義されている日付と時間コード
DATE
              で指定する
EXT
              必須項目、MAN ヘッダが理解されたかどうかの確認(ヘッダのみ、値なし)
              必須項目、OS 名, OS バージョン、UPnP/1.0、製品名および製品バージョンを連記したもの。文字列
SERVER
ボディ
         SOAPが定義する必須エレメント. xmlnsの名前属性は、必ず http://schemas.xmlsoap.org/soap/envelope/ "となる.
Envelope
         また,必ず"http://schemas.xmlsoap.org/soap/encoding/ "という値の encodingStyle 属性を含む.以下のサブエレメ
         ントを含む
              SOAP が定義する必須エレメント、SOAP ネームスペースにより認可されたもの、以下のサブエレメントを含む
                    SOAP が定義する必須エレメント。サービスが変数の値を返せなかった理由、SOAP ネームスペースにより認
                     可されたもの. 以下のサブエレメントを含む
                                 SOAP が定義する必須エレメント. 値は SOAP ネームスペースにより認可されたもの.
                     faultcode
                                 Client でなくてはならない
                     faultstring
                                 SOAP が定義する必須エレメント、errorCode を記述する包括的な UPnP 文字列.
                                 表 15 参照
                     detail
                                 SOAP が定義する必須エレメント. 以下のサブエレメントを含む
                                            UPnP が定義する必須エレメント、以下のサブエレメントを含む
                                            errorCode
                                                           UPnP が定義する必須エレメント、どのエラー
                                                           が発生したかを識別するコード.表17参照.
                                                            整数
                                                           UPnPが定義する推奨エレメント. 短い説明.
                                            errorDescription
                                                           表9参照. 文字列. 256 文字未満であることが
                                                           推奨される
```

#### 〔表9〕 クエリのエラーコード

| errorCode | errorDescription | 記述                                     |
|-----------|------------------|----------------------------------------|
| 404       | Invalid Var      | このサービスには指定された値の状態変数は存在しない              |
| 600-624   | TBD              | 共通アクションエラー.UPnP Forum WC により定義         |
| 625-649   | TBD              | 将来の使用のためリザーブされている                      |
| 650-674   | TBD              | 標準アクションのアクション固有エラー.UPnP Forum WC により定義 |
| 675-699   | TBD              | 非標準アクションのアクション固有エラー. UPnPベンダにより定義      |

#### 〔図3〕イベンティングの動作



なお、定義されたエラータイプ(errorCode および errorDescription)エレメントに対応する値を**表9**に示します.

### イベンティング トトトトトトトトト

イベンティングは、UPnPネットワークではステップ4になります。コントロールポイントがディスカバリ(ステップ1)、デバイスとサービスのディスクリプション(ステップ2)を終了した時点で、コントロールポイントはイベンティングの処理に移ることができます。コントロール(ステップ3)はイベンティングと連携しますが、実行されている必要はありません。

では、イベンティングは、どのような状況で有効なのかを解説します。コントロールポイントがアクションを実行した場合、 当然コントロールポイントは結果を知ることができます。しかし、アクションの実行とは関係なくデバイスの状況が変わる場合はどうでしょうか? たとえば、"プリンタのインクや紙が切れた"や"セキュリティシステムが異常を検知した"というような場合です。この場合、何らかの通知が必要になります。

イベンティングは、変化があったときすべてのコントロールポイントへマルチキャストで通知するわけではありません。コントロールポイントは、あらかじめチェックしておきたいデバイスのサービスへ通知を要求します。これをサブスクライブ(以降、購読と記述)と呼びます。サービス(イベンティングでは、このときのサービスをパブリッシャーと呼ぶ)は要求したコントロールポイント(購読するコントロールポイントをイベンティングではサブスクライバーと呼ぶ)へだけ、個別にユニキャストで通知します。サブスクライバー(以降、購読者と記述)およびパブリッシャー(以降、発行者と記述)がイベントメッセージに関して行うことを説明します。

#### 1) サブスクライブリクエスト

購読者が発行者へイベントメッセージを受け取るためのリクエストメッセージを送信します。

#### 2) サブスクライブレスポンス

発行者は、購読を許可するためのレスポンスメッセージを送信し購読者からの要求を登録します。このとき購読のタイムアウト時間をメッセージ内に示します。この時間が過ぎるまでに、購読者はタイムアウト時間を更新するため、再度サブスクライブリクエストメッセージを送信する必要があります。新聞を購読しているのに1か月ごとに要求しないと新聞配達が止まってしまうというようなしくみです(日本の場合は断らないと新聞配達は止まらないが)。

UPnPでも明示的に断りたい場合があります。それが 3) アンサブクライブです。

#### 3) アンサブスクライブ

購読者は登録された要求をキャンセルしたいときがあります. 購読者は発行者へアンサブスクライブメッセージを送信し, キャンセルします.

#### 4) アンサブスクライブレスポンス

発行者はキャンセルされたことを知らせるためのレスポンス メッセージを送信します.

#### 5) イベンティング

発行者はサービスの状態変数が変化した場合, イベントメッセージを購読者へ送信します.

#### 6) イベンティングレスポンス

購読者は、イベントメッセージを受信したことを知らせるためレスポンスメッセージを送信します。

以上までのイベンティングの動作のまとめを**図3**に、イベンティングにおいて使用するプロトコルを**図4**に示します。

イベントメッセージは、GENAメソッド/ヘッダを用いて

#### 〔図 4〕 イベンティングにおいて使用するプロトコル =



フォーマットされ、HTTPを介してTCP/IPにより配信されます.

もう少しイベンティングについて説明します. 購読者が発行者へ" 購読する"と伝えると、発行者は最初に特殊なイベントメッセージを発行します. これをイニシャルイベントメッセージといいます. このメッセージにはイベントとして通知しなければならない変数の名前と、その時点でのすべて変数の値が含まれます.

購読者は、この情報を初期値として保存する必要があります. なぜ、このようなことをするかというと、イベントメッセージを 変数単位で購読するためのメカニズムがないからです。そのため 購読時には、すべての変数の情報が発行者から送られます。購読 者は、初期値と比較して各変数が変化したことを認識します。

発行者は、各購読者からのサブスクライブリクエストを管理 するため四つの情報をもったリスト(サブスクライバーリスト) を管理する必要があります.

#### 1) SID (subscription identifier)

特定の購読を管理するための識別子. 普遍的な一意の値でなくてはなりません. 発行者はサブスクライブレスポンスのメッセージにこれをセットし, 購読者がリクエストした購読を識別できるようにします.

#### 2) delivery URL for event messages

購読者がイベントメッセージを受け取れるURLを、サブスクライブメッセージに含めて送信します。発行者はこれを保存し、イベントメッセージを送信しなければならないときに参照します。

#### 3) event key

このキーはカウンタになっています。イニシャルイベントメッセージの場合、このキーはoとなります。イベントメッセージを送信するごとにシーケンシャルにインクリメントします。連続した番号を受け取ることで、購読者はイベントメッセージに損失がないことを確認できます。

#### 4) subscription duration

購読の有効時間です。この時間が過ぎる前に更新のサブスクライブメッセージを受け取らなければ、発行者は、この購読を 無効にします。

これらの情報によりイベントメッセージを制御します.

次にタイムアウトに関して説明します。UPnPネットワークでは、購読の有効時間を決めることが可能です。これは、ディスカバリの CACHE-CONTROL と同じ時間が良いでしょう。購読者は、この時間内に発行者へ更新のサブスクライブメッセージを送信します。更新することでリスト内の購読が有効であるこ

#### 〔表 10〕 サブスクライブメッセージ

SUBSCRIBE publisher path HTTP/1.1
HOST: publisher host: publisher port
<SPAN class=gena>CALLBACK: <delivery URL>
NT: UPnP:event
TIMEOUT: Second-requested subscription duration
<BR>

(サブスクライブメソッドのリクエストにはボディはないが、メッセージの最後にブランクラインが必要)

|           | (サノハソノイノハノ                                                                                                                        | (リング) ノイングラットのリッチストにはホティははいが、グラモーンの取扱にフランテラインが必要)                                                                                       |  |  |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|--|--|
| リクエストライン  |                                                                                                                                   |                                                                                                                                         |  |  |
| SUBSCRIBE | GENA により定義さ                                                                                                                       | れたメソッド                                                                                                                                  |  |  |
|           | publisher path                                                                                                                    | イベンティング URL (デバイスディスクリプションのサービスエレメントの eventSubURL サブエレメント) のパスコンポーネント.単一の相対 URL                                                         |  |  |
|           | HTTP/1.1                                                                                                                          | HTTPバージョン                                                                                                                               |  |  |
| ヘッダ       |                                                                                                                                   |                                                                                                                                         |  |  |
| HOST      |                                                                                                                                   | 必須項目、イベント URL (デバイスディスクリプションのサービスエレメントの eventSubURL サブエレメント)のドメイン名または IP アドレスおよび任意のポートコンポーネント、ポートが空の場合、あるいは明記されていない場合、80が用いられる          |  |  |
| CALLBACK  | サービスがイベント                                                                                                                         | GENAが定義する必須ヘッダ. イベントメッセージの送信先. UPnPベンダにより定義. 複数のURLが存在する場合,<br>サービスがイベントを送信する際, いずれかが成功するまでこれらのURLを順に試す. 一つ以上のURLは, アングルブ<br>ラケットで区切られる |  |  |
| NT        | GENA が定義する必                                                                                                                       | GENA が定義する必須ヘッダ. 通知タイプ (Notification Type) のこと. UPnP: event でなくてはならない                                                                   |  |  |
| TIMEOUT   | OUT 推奨項目. サブスクライブが期限切れになるまでの期間. 砂数または無限. UPnP Forum WC により推奨される. UPn ベンダにより定義. キーワード Second-の後に整数値が続く(スペースなし), あるいは infinite (無限) |                                                                                                                                         |  |  |

#### 〔表 11〕 サブスクライブメッセージレスポンスで発生するエラー

#### Incompatible headers

400 Bad Request. SIDヘッダおよびNTまたはCALLBACKヘッダのいずれかが存在する場合,発行者はHTTPエラー400 Bad Requestで応答する

#### Missing or invalid CALLBACK

412 Precondition Failed. CALLBACKへッダがない場合, あるいは有効な HTTP URLを含んでいない場合, 発行者は HTTPエラー412 Precondition Failedで応答する

#### Invalid NT

412 Precondition Failed.NTヘッダがUPnP:eventでない場合,発行者はHTTPエラー412 Precondition Failedで応答する

#### Unable to accept subscription

5xx 発行者が購読を許可できない場合、HTTP 500-シリーズのエラーコードで応答する

#### とが確認されます。

では、タイムアウトしてしまったら、どうなるのでしょうか? 発行者はイベントメッセージの送信をやめるのと同時に、SID (サブスクライブ識別子)をリストから削除します。また反対に 購読者は購読した発行者からのディスカバリメッセージを監視 します。もし、ディスカバリメッセージ(以降 DevMsg と記述) を受け取った場合、デバイスが購読をキャンセルしている可能 性が大きいでしょう。その場合、再度購読する必要があります。

#### • サブスクライブメッセージ

デバイスディスクリプション(以降 DevDesc と記述)のサービスエレメント内にサービスのイベント URL があります。そこへ購読者はサブスクライブメッセージを送ります。このメッセージの形式を解説します。まず、購読者が最初に送信するサブスクライブメッセージを表 10 に示します。

#### ▶サブスクライブメッセージレスポンス

発行者が購読を許可するときは、購読者に SID と購読のタイムアウト時間を割り当て、予定転送時間を含め 30 秒以内に表

#### 〔表 12〕 サブスクライブレスポンスメッセージ

<BR>

HTTP/1.1 200 OK
DATE: when response was generated
SERVER: OS/version UPnP/1.0 product/version
<SPAN class=gena>SID: uuid: subscription-UUID
T IMEOUT: Second-actual subscription duration

(サブスクライブメソッドのリクエストに対する応答にはボディはないが、メッセージの最後にブランクラインが必要)

| イはないが、メッセーンの取扱にフランクラインが |                                                                                                                                                                  |  |  |  |  |  |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| ヘッダ                     |                                                                                                                                                                  |  |  |  |  |  |
| DATE                    | 推奨項目. レスポンスメッセージが生成された日付. RFC<br>1123 の日付                                                                                                                        |  |  |  |  |  |
| SERVER                  | 必須項目、OS 名,OS バージョン,UPnP/1.0,製品名および製品バージョンを連記したもの.文字列                                                                                                             |  |  |  |  |  |
| SID                     | GENA が定義する必須ヘッダ. サブスクライブの識別 庁(ID).<br>必ず uuid: で始まる.UPnP ベンダにより定義.単一の URI                                                                                        |  |  |  |  |  |
| TIMEOUT                 | 必須項目. サブスクライブが期限切れになるまでの実際の期間. 秒数または無限. UPnP Forum WC により推奨される. UPnP ベンダにより定義. 1800 秒(30分)より長く設定することが好ましいとされる. キーワード Second-の後に整数値が続く(スペースなし), あるいは infinite(無限) |  |  |  |  |  |

11 の形式のレスポンスメッセージを送信します.次に発行者はイニシャルイベントメッセージを購読者へ送信します.このレスポンスメッセージを表12に示します.発行者が購読を許可できない場合,あるいはサブスクライブリクエストにエラーが発生した場合,発行者は表11のエラーのうちのいずれかを応答として送信します.レスポンスは、予定転送時間を含め30秒以内に送信されなくてはなりません.

#### ▶更新サブスクライブメッセージ

以前リクエストした購読を更新するため、イベント URL へ送信します。サブスクライブメッセージと異なり、イベントメッセージを受信するための URL を含みませんが、代わりに SID が入ります。発行者は SID で判断ができます。このメッセージを表 13 に示します。

発行者が購読の更新を許可するときは、サブスクライブメッ

#### 〔表 13〕更新サブスクライブメッセージ

SUBSCRIBE publisher path HTTP/1.1
HOST: publisher host: publisher port
<SPAN class=gena>SID: uuid: subscription UUID
T IMEOUT: Second-requested subscription duration
<BR>

|           | (サブスクライブメソッドのリクエストにはボディはないが、メッセージの最後にブランクラインが必要)                                                                                   |                   |                                                                                 |
|-----------|------------------------------------------------------------------------------------------------------------------------------------|-------------------|---------------------------------------------------------------------------------|
| リクエストライン  |                                                                                                                                    |                   |                                                                                 |
| SUBSCRIBE |                                                                                                                                    | GENA により定義されたメソッド |                                                                                 |
|           |                                                                                                                                    | publisher path    | イベンティング URL (デバイスディスクリプションのサービスエレメントの eventSubURL サブエレメント) のパスコンボーネント.単一の相対 URL |
| HTTP/1.1  |                                                                                                                                    | HTTPバージョン         |                                                                                 |
| ヘッダ       |                                                                                                                                    |                   |                                                                                 |
| HOST      | 必須項目. イベント URL(デバイスディスクリプションのサービスエレメントの eventSubURL サブエレメント) のドメイン名または IP アドレスおよび任意のポートコンポーネント. ポートが空の場合、あるいは明記されていない場合, 80 が用いられる |                   |                                                                                 |
| SID       | GENA が定義する必須ヘッダ、サブスクライブの ID. サブスクライブリクエストへの応答としてバブリッシャーから割り当てられた SID でなくてはならない。必ず uuid: で始まる。UPnP ベンダにより定義。単一の URI                 |                   |                                                                                 |
| TIMEOUT   | 推奨項目. サブスクライブが期限切れになるまでの期間. 砂数または無限. UPnP Forum WC により推奨される. UPnP ベンダにより定義. キーワード Second-の後に整数値が続く(スペースなし), あるいは infinite (無限)     |                   |                                                                                 |

#### 〔表 14〕更新サブスクライブメッセージで発生するエラー

#### Incompatible headers

400 Bad Request. SIDヘッダおよびNTまたはCALLBACKヘッダのいずれかが存在する場合, 発行者はHTTPエラー400 Bad Requestで応答する

#### Invalid SID

412 Precondition Failed、SIDへッダの期限が切れていない,予定外の既知の購読に対応していない場合,発行者はHTTPエラー412 Precondition Failedで応答する

#### Missing SID

412 Precondition Failed、SIDへッダが存在しない場合あるいは空の場合,発行者はHTTPエラー412 Precondition Failed で応答する

#### Unable to accept renewal

5xx.発行者が更新を許可できない場合, HTTP 500-シリーズのエラーコードで応答する

#### 〔表 16〕アンサブスクライブレスポンスで発生するエラー

#### Incompatible headers

400 Bad Request. SID ヘッダおよび NT または CALLBACK ヘッダのいずれかが存在する場合,発行者は HTTP エラー 400 Bad Request でレスポンスする

#### Invalid SID

412 Precondition Failed. SIDヘッダの期限が切れていない既知の購読に対応していない場合, 発行者はHTTPエラー412 Precondition Failedでレスポンスする

#### Missing SID

412 Precondition Failed、SIDへッダが存在しない場合あるいは空の場合、発行者はHTTPエラー412 Precondition Failed でレスポンスする

セージのレスポンスと同じ形式のメッセージを 30 秒以内 (予定 転送時間を含む) にレスポンスメッセージを送信します。発行 者が購読の更新を許可できない場合、あるいはサブスクライブ リクエストにエラーが発生した場合、発行者は表 14 のエラー のうちのいずれかを応答として送信します。レスポンスは、予 定転送時間を含め、30 秒以内に送信されなくてはなりません。

#### ▶アンサブスクライブ

購読者は、発行者の状態をチェックすることが不要になると、 購読をキャンセルします. このメッセージの形式を**表 15** に示 します.

#### ▶アンサブスクライブレスポンス

購読をキャンセルするために、発行者は予定転送時間を含め30秒以内に以下の形式でレスポンスしなければなりません.

HTTP/1.1 200 OK

(NOTIFY メソッドのリクエストにはボディはないが、メッセージの最後にブランクラインが必要)

キャンセルリクエストにエラーが発生した場合,発行者は**表 16** のエラーのうちのいずれかをレスポンスします.

#### • イベントメッセージ

ここでイベントメッセージの形式を説明しますが、その前に event key に関してだけ説明します。発行者は、イベントメッ セージを購読者へ送るたびに event key をインクリメントしま

#### 〔表 15〕アンサブスクライブメッセージ

UNSUBSCRIBE publisher path HTTP/1.1 HOST: publisher host: publisher port <SPAN class=gena>SID: uuid: subscription UUID (アンサブスクライブメソッドのリクエストにはボディはた いが、メッセージの最後にブランクラインが必要) リクエストライン GENA により定義されたメソッド。サブスクライブ UNSUBSCRIBE をキャンセルする イベンティング URL(デバイス publisher path ディスクリプションのサービ スエレメントの eventSubURL サブエレメント) のパスコンポ ーネント、単一の相対 URL HTTP/1.1 HTTPバージョン ヘッダ HOST 必須項目、イベンティング URL(デバイス記述のサービス エレメントの eventSubURL サブエレメント) のドメイン 名または IP アドレスおよび任意のポートコンポーネント. ポートが空の場合、あるいは明記されていない場合、80 が用いられる GENA が定義する必須ヘッダ. サブスクライブの ID (識別 STD 子). サブスクライブリクエストへのレスポンスとしてパ ブリッシャーから割り当てられたサブスクライブIDでな くてはならない. 必ず uuid:で始まる. UPnPベンダによ り定義。単一の URI

す(イニシャルイベントメッセージを送付したときにoにリセットされる). これを購読者はチェックします. たとえば, event key が3のイベントメッセージの後に6のメッセージを購読者が受け取れば,4と5のイベントメッセージを受信し損ねています. このようなとき,購読者はその購読をキャンセルし,再度購読する必要があります. イベントメッセージの形式を表17に示します.

#### ▶イベントメッセージレスポンス

購読者がイベントメッセージを受信したことを発行者へ知らせるため、予定転送時間を含め30秒以内に以下の形式のレスポンスメッセージを送信します。

HTTP/1.1 200 OK

(NOTIFY メソッドのリクエストにはボディはないが、メッセージの最後にブランクラインが必要).

イベントメッセージにエラーが発生した場合, 購読者は**表 18** のエラーのうちのいずれかをレスポンスとして送信します. レスポンスは, 予定転送時間を含め30秒以内に送信されなくてはなりません.

### プレゼンテーション トトトトトトトト

プレゼンテーションは、UPnPネットワークにおけるステップ5です。コントロールポイントがディスカバリ(ステップ1)、デバイスとサービスのディスクリプション(ステップ2)を終了した時点で、コントロールポイントはプレゼンテーションの

#### 〔表 17〕イベントメッセージ

NOTIFY delivery path HTTP/1.1 HOST: delivery host:delivery port CONTENT-TYPE: text/xml CONTENT-LENGTH: Bytes in body NT: upnp:event NTS: upnp:propchange SID: uuid:subscription-UUID SEQ: event key <e:propertyset xmlns:e="urn:schemas-upnp-org:event-1-0"> <e:propertv> <variableName>new value</variableName> </e:property> Other variable names and values (if any) go here. </e:propertyset> リクエストライン GENA により定義されたメソッド、クライアントにイベントについて告知する NOTIFY 配信 URL(サブスクライブメッセージの CALLBACK ヘッダ) のパスコンポーネント. イベントメッセージ delivery path の送信先. 単一の相対 URL HTTP/1.1 HTTPバージョン HOST 必須項目,配信 URL(サブスクライブメッセージの CALLBACK ヘッダ) のドメイン名または IP アドレスおよび任意のポート コンポーネント.ポートが空の場合,あるいは明記されていない場合,80が用いられる 必須項目. バイト単位で示したボディの長さ. 整数 CONTENT-LENGTH 必須項目. text/xml でなくてはならない CONTENT-TYPE GENA が定義する必須ヘッダ. 通知タイプ (Notification Type) のこと. UPnP: event でなくてはならない NTNTS GENA が定義する必須ヘッダ、通知サブタイプ (Notification Sub Type) のこと、UPnP: propchange でなくてはならない GENA が定義する必須ヘッダ、サブスクライブの ID(識別子)、必ず uuid:で始まる、UPnP ベンダにより定義、単一の URI SID UPnP が定義する必須ヘッダ、イベントキー、イニシャルイベントメッセージの場合キーは 0 となる、特定のサブスクライ SEO ブバーに送信される各イベントメッセージに対し1ずつインクリメントする. 長さ8バイト. オーバフローを防ぐため-のインテジャー型になる。単一の整数 ボディ 必須項目. xmlns ネームスペース属性は、必ず urn: schemas-UPnP-org:event-1-0 になる。すべてのサブエレメントは propertyset このネームスペースにより認可されたもの。以下のサブエレメントを含む property 必須項目. イベントメッセージの各変数名および値に対し1度繰り返す ネームスペースにより認可されたもの。以下のサブエレメントを含む propertyset variableName |必須項目. エレメントは、変化した状態変数の名前(サービスディスクリプションの stateVariable エレメントの name サブエレメント). propertyset ネームスペースによ り認可されたもの、Valuesは、この状態変数の新しい値、UPnPサービスディスクリプシ ョンで指定される単一のデータ型

処理に移ることができます.コントロール (ステップ3) イベンティング (ステップ4) と連携しますが,実行されている必要はありません.プレゼンテーションは,どちらかというとコントロールやイベントの補助的なものです.プレゼンテーションによって,デバイスがもつ Web サービスを IE などの Web ブラウザで表示することができます.これにより Web ページからのデバイス制御,サービスの状態変数を知ることができます.プレゼンテーションの動作イメージを**図5** に示します.

プレゼンテーションのための URL は、Dev Desc の presentation URL エレメントに含まれています。 プレゼンテーションページを取得する場合、コントロールポイントは HTTP GET リクエストをプレゼンテーション URL に対して発行し、デバイスがプレゼンテーションページを返します。 UPn P Device/Service Template、標準デバイスおよびサービスタイプと異なり、プレゼンテーションページの機能は UPn P ベン

#### 〔表 18〕イベントメッセージレスポンス時に発生するエラー

#### Missing SID

412 Precondition Failed、SID ッダが存在しない場合,あるいは空の場合,購読者は HTTP エラー412 Precondition Failed でレスポンスする

#### Invalid SID

412 Precondition Failed. SIDヘッダが期限の切れていない既知の購読に対応していない場合, 購読者はHTTPエラー412 Precondition Failedでレスポンスする(サービスは, このエラーメッセージを受け取った場合このSIDを破棄する)

#### Missing NT or NTS header

400 Bad Request. NTまたはNTS ヘッダが存在しない場合, 購読者はHTTPエラー400 Bad Request でレスポンスする

#### Invalid NT header

412 Precondition Failed. NTヘッダがUPnP:eventでない場合, 購読者はHTTPエラー412 Precondition Failedでレスポンスする

#### Invalid NTS header

412 Precondition Failed. NTヘッダがUPnP:prochange でない場合, 購読者はHTTPエラー412 Precondition Failedでレスポンスする

#### 〔図5〕プレゼンテーションの動作



ダにより自由に使用できます. プレゼンテーションページは, UPnP Forum WCの対象ではありません. Webページは, 必ずバージョン 3.0 以降の HTMLページでなくてはなりません. しかし, 他のデザイン要因はベンダが指定できます. これにはコントロールポイントの Web ブラウザの全機能, 使用するスクリプト言語またはブラウザプラグイン, そしてデバイスとの対話手段などが含まれます.

プレゼンテーションページを配置するため、UPnPベンダはコントロールやイベンティング、デバイスの既存機能の強化などのためのUPnPメカニズムを用いることができますが、それ以外の選択肢もあります(よく聞く質問で、プレゼンテーションで実行される制御はUPnPのコントロールなどを使用するべきか?というものがあるが、答えはNoである。独自でもコントロールを使ってもかまわない)。

プレゼンテーションページでは、HTMLが提供するローカライズのためのメカニズム(例: charset 属性をもつMETA タグなど)を用いる必要があります。コントロールポイントでは、ローカライズされたプレゼンテーションページを取得するためにHTTPのACCEPT-/CONTENT-LANGUAGE機能を用います。具

体的には、コントロールポイントはプレゼンテーションページ に対するリクエストに HTTP の ACCEPT-LANGUAGE ヘッダを 含めることができます。ACCEPT-LANGUAGE ヘッダがリクエス トに含まれている場合、レスポンスには必ずページの言語を識 別するための CONTENT-LANGUAGE ヘッダが含まれます。

#### まとめ

Universal Plug and Play Device Architecture V1.0のスペックの話をしてきましたが、詳細に関してはスペックそのものを参照してください。これまでの話は、UPnPデバイスアーキテクチャ V1.0 や各 DCP のスペックを理解する上での助けになると思います。なお、機会があれば、各 DCP のスペックの解説や Windows XPの UPnP API の紹介をしたいと考えています。

#### 参考文献

- Universal Plug and Play Device Architecture V1.0, http://www.upnp.org/download/UPnPDA10\_20000613.htm
- 2) Simple Service Discovery Protocol(SSDP), http://www.upnp.org/download/draft\_cai\_ssdp\_v1\_03.txt
- Multicast and Unicast UDP HTTP Messages, http://www. upnp.org/download/draft-goland-http-udp-04.txt
- 4) General Event Notification Architecture (GENA), http://www. upnp.org/download/draft-cohen-gena-client-01.txt
- 5) Sample Device and Service Templates, http://www.upnp.org/resources/devices.asp
- 6) Windows XP Ø Universal Plug and Play, http://www.microsoft .com/japan/windowsxp/pro/techinfo/planning/upnp/Unive rsalPlugandPlayinWindowsXP.doc
- 7) Simple Object Access Protocol(SOAP), http://www.w3.org /TR/SOAP/, http://www.microsoft.com/japan/developer /workshop/xml/general/soapspec.asp
- 8) Extensible Markup Language (XML), http://www.w3.org/XML/

ちゃま・やすし テクニカルライター

#### Interface BackNumber 2002年 [12月号] 多国語文字コード処理&国際化の基礎と実際 co-romge オブジェクト指向の実装技法入門 5月号 2003年 1月号 これでわかる!マイクロプロセッサのしくみ 6月号 作りながら学ぶコンピュータシステム技術 cd-ROM付き ワイヤレスネットワーク技術入門 Linux 徹底詳解 — ブート&ルートファイルシステム 2 月号 7月号 CD-ROM付 8月号 3月号 組み込み分野への BSD の適用 IC カード技術の基礎と応用 9月号 基礎からの計算科学・工学 ― シミュレーション 4月号 解説! USB 徹底活用技法 CD-ROMHE® うまくいく!組み込み機器の開発手法 10月号 データベース活用技術の徹底研究 [5月号] 11月号 6 月号 徹底解説! ARM プロセッサ TCP/IP の現在と VoIP 技術の全貌

# **(**

### 安達健一





Advanced Configuration and Power Interface

従来、PC/ATの電力管理には APM (Advanced Power Management) が使われてきた. しかし、昨今のハードウェアの進化によって、APM では要求に応じられないような局面も出てきた.

そこで登場した ACPI (Advanced Configuration and Power Interface) は、電力管理はもちろんのこと、多様な資源のコンフィグレーションを可能にしている。

本稿では、注目が集まっている ACPI に関して、実例をまじえて解説を行う.

(編集部)

最近のPCでは、パワーマネジメントとリソースコンフィグレーションを実現する土台として、ACPIが必要不可欠となってきています。本稿では、ACPIの核となる基本コンセプトを平易に解説し、難解とされるACPI仕様書を読み解く道しるべを示します。

## ☆ ACPIの基本コンセプト

現時点では、ACPIに未対応のPCもありますが、最近の機種であれば原則としてACPIに準拠しています。さらに、一部にはパワーマネジメントとリソースコンフィグレーションの基盤として、ACPIしかサポートしないモデルも登場し始めています。

そこで、ここではなぜ ACPI が必要とされるのか、ACPI の基本コンセプト/ACPI へといたる歴史を簡単に確認しておきます.

ACPIという言葉は、Advanced Configuration and Power Interface の略で、その名が示すように Configuration: リソースコンフィグレーションと、Power:パワーマネジメントを司るうえで、プラットホームハードウェアとシステムソフトウェアのインターフェースとなるものです。

#### ● ACPI以前 —— BIOS への依存

ACPI が登場する以前から、これらの機能は PnP BIOS やAPM BIOS の規格にのっとり、OS と BIOS が協調する形で実現されていました。

しかし、その方法はBIOSが「主人公」に近い位置を占め、システムボードに関わる情報の収集・管理から意思決定、そして具体的な処理の実行にいたるまで、すべてがBIOSに深く依存したものでした。

したがって、これら ACPI 以前の方式でリソースコンフィグレーションやパワーマネジメントを行う場合、OS 上で実行される通常のプロセスから見て問題となる点がいくつかありました.

#### システム管理モード

なかでも、OS の実行中にランタイムでシステム管理割り込み (SMI: System Management Interrupt) を発行し、システム管理モード (SMM: System Management Mode) という、OS から「見えない」モードで BIOS 側の用意したハンドラを実

行するしくみは、危険性が高いものです.

なぜなら、システム管理モードでは OS のすべての処理の実行は、ごくわずかな時間ですが停止させられてしまい、このとき実行される BIOS 側のコードに障害があればシステムのハングアップといった致命的な問題が発生し、OS 側では対処する術がないからです (図  $\mathbf{1}$ ).

また、システム管理モードは OS からは透過的であり、本来であれば OS の実行環境に影響を与えないはずですが、濫用されると OS 上のコンテクストの整合性が損なわれてしまうこともありました。

#### ● ACPI —— OS による中央集権的な管理

そこで、ACPIでは OSPM — Operating System Directed Configuration&Power Management という、リソースコンフィグレーションやパワーマネジメントに関わるすべての情報を OS に集約し、BIOS は具体的な手段を提供するだけで、その手段の実行は OS の意思決定のもと、OS の制御下で行われるというコンセプトが取り入れられました (図 2).

ACPIでは、BIOS が ASL(ACPI Source Language)という言語を用いて、ACPI管理下にあるデバイス間の論理関係や制御手順を記述し、BIOS ROM に格納しておきます.

そして、システム起動時に BIOS がこれらの ACPI 関連情報をメインメモリに展開し、OS が立ち上がると OS 内に実装された ACPI サブシステムが BIOS から渡された情報を解析して、パワーマネジメントとリソースコンフィグレーションを実現する基盤となる情報を得ます。

#### 〔図 1〕SMI ハンドラで重大な障害が発生



# ひ ① ※

#### 「図2」ACPIの基本コンセプト



これ以降は、OSが中央集権的にパワーマネジメントやリソースコンフィグレーションに関する情報の収集/管理から意思決定、そして具体的な処理の実行にいたるまでをコントロールします。

ACPI 対応システムでは、OS 実行中にプラットホームハードウェア上で、たとえば電源ボタンが押されたり、温度があるしきい値を超えたり、バッテリが取り外されたり……といった ACPI の管理対象であるイベントが発生すると、ACPI のコアロジック部分(通常はチップセット内のレジスタとして実装)を経由してSCI: System Control Interrupt という割り込みがかかります.

OS は SCI を受け付けると、ACPI イベントのソースを特定し、必要に応じて BIOS が提供するコントロールメソッドと呼ばれるコードを実行するなどして ACPI イベントを適切にハンドルします。

この ACPI イベントのハンドリングが、ACPI の基本コンセプトに基づき、OS の制御下で、OS から「見える」モードで実行される点がポイントです。

# 兴

### ACPI対応OSの現状

ハードウェア/BIOS については前述のとおり、現在ほとんどの PC が ACPI に準拠しています。一方、ACPI 対応 OS としては、マイクロソフトの Windows 2000 以降の NT カーネルベースの OS が ACPI 仕様書 1.0b に準じた完成度の高い ACPI サポートを実現しています。

同社の最新クライアント OS である Windows XP では、プロセッサドライバなど ACPI2.0 のいくつかの新機能も追加サポート  $^{1\pm 1}$  され、ACPI を全面的に利用したシステムワイドなパワー



#### コラム1

#### ACPIへの道程

今から 10 年ほど前、インテルが PC にはじめてパワーマネジメントという概念を取り入れようとしたとき、業界からはほとんど相手にされなかったと聞きます.

しかし、その後、当時"Wintel"ともいわれ、蜜月関係にあったマイクロソフトの協力をとりつけたことで、PCベンダも理解を示し始め、1990年代後半にはAPM 規格がノート型コンピュータでは積極的に採用されるようになりました。

しかし、APM は本稿で述べたように、BIOS が意思決定にまで介入するという性格であったこと、さらには機能拡大につれてベンダ間でのバラつきや、BIOS ROM の容量を圧迫するといった課題が顕在化してきました。

ACPI は、そうした APM の問題点をふまえ、システムの状態についてもっとも正確な情報を知り得る OSが、中央集権的にパワーマネジメントを司るアプローチを取っています。

ただし、ACPI はたんに APM を置き換えるだけのものではなく、APM と同様に、限界が見え始めていた PnP BIOS や、本稿ではふれていませんが、マルチプロセッサシステムで採用されていた MPS などの規格についても、BIOS 主導から OS 中心に切り替える 役割を果たすものです.

ACPI 仕様書を細かく見ていくと、じつに多彩な内容がカバーされた規格であることがわかります。見落とされがちですが、IDE、FDD などのニッチな部分についても標準化を試みていたりと、とても意欲的です。そして、そのどれにも共通しているのが、BIOS依存部分をOS主導に、というパラダイムの転換です。

注1: ACPI テーブルの 64 ビットフィールド対応、プロセッサ省電力テクノロジ、PCI ホットプラグの 3 機能だけが新たに実装されている.

# ACPIによるPC/ATの電力管理とコンフィグレーション

#### 〔図 3〕 Windows XP デバイスマネージャの画面



マネジメントとリソースコンフィグレーションを達成しています(**図3**).

同じマイクロソフトの OS でも、コンシューマ向けの Windows 98 SE や Windows Me では、当初の開発時点でハードウェア / BIOS 側の ACPI サポートがまだ未成熟であったこともあり、一部 ACPI 仕様から外れた実装方式  $^{\pm 2}$  で ACPI サポートが実現されています。

また、PC UNIX の中にも、積極的に ACPI サポートを実現しようとする活動が広がっています。たとえば Linux では、カーネル 2.5.x から ACPI サブシステムのコードがツリーに標準で入り、インテルのエンジニアがリーダーシップを取って ACPI サポートを完成させつつあります。

おもだった Linux ディストリビュータの中にも、Red Hat などのように自社のパッケージで ACPI の標準サポートを表明するところが出てきました.

#### • ACPI サブシステムの位置付け

OSがより高度なパワーマネジメントとリソースコンフィグレーションを実現するとき、まずはカーネルやデバイスドライバ側にこうした機能を意識したインフラストラクチャが確立されていることがたいへん重要となります。

ACPI サブシステムは、実行部隊として ACPI イベントを検出したり、カーネルやデバイスドライバの判断・意思決定の結果として実行が必要となったタスク、たとえばシステムやデバイスをスリープステートに落とす、あるいは ACPI 管理下のデバイスを列挙して有効にし、リソースを割り当てるといった作業を遂行するためにハードウェア資源にアクセスするレイヤです(図4).

注2: 一部の ACPIメソッドは使用を推奨しないなどといった措置がとられた。

#### 〔図4〕ACPIサブシステムの位置づけ

システムワイドなパワーマネジメントと リソースコンフィグレーションのインフラストラクチャ



#### Windows Driver Model ∠ ACPI

Windows XPをはじめとするマイクロソフトの最近の OSでは、カーネルがパワーマネジメントやリソースコンフィグレーションについて中央集権的に支配しています。また、デバイスドライバも Windows Driver Model (WDM) に即して、パワーマネジメントおよびリソースコンフィグレーションを統一された方式でサポートしています。

このため、システムスタンバイや休止状態という、とくにノート PCユーザーから強い要望のある機能についても、カーネルと各デバイスドライバがパワーマネジメント用の IRP(I/O リクエストパケット)を介し一貫性のある処理を進め、必要な部分で ACPI サブシステムを利用して目的を達成します(図5).

カーネル側の意思決定を担う部分と ACPI サブシステムとは きちんと分離されていて,カーネル側は ACPI を利用して情報 を収集して判断を下し,ACPI サブシステムは実行部隊として の役割に徹することができます.

#### Intel ACPI Component Architecture

インテルが、現在 Linux 上で開発に注力している ACPI サブシステム (ACPI Component Architecture) もカーネル部分から独立した実行部隊として設計され、さらに理論上はホスト OS 非依存の実装を目指しています。

しかしながら、WindowsのようなプロプライエタリなOSと違ってオープンソース系のOSでは、カーネル中枢に新たな機能を追加したり、デバイスドライバにパワーマネジメントやリソースコンフィグレーションを意識した統一の約束事を徹底することが容易ではありません。

とりわけ Linux のような、ポピュラーで関係する開発者の多

# ひ 〇 ※

#### 「図 5) Windows Driver Model と ACPI



#### 〔図 6〕Linux における ACPI コンポーネントアーキテクチャ



(Intel, ACPI, CAプログラマーズマニュアルより引用)

いプロジェクトでは、この傾向が強くなります。カーネル 2.5 以降の試みとして、Linux Driver Model という Windows の WDM に似たデバイスドライバ実装の指針が検討されているようですが、少なくとも現時点では強固なインフラストラクチャは確立されていません(図 6)。そのため、Windows のように ACPI をきちんと利用したシステムスタンバイや休止状態を実現するにはまだ時間を要しそうです。

# ★ ACPI仕様書

冒頭に述べたように、「ACPI 仕様書は難しい」という声をよく耳にします。その理由として、以下の点を指摘できます。

① 構成上の問題

扱う対象の種類が多く、範囲も広いため、関連するさまざま

話題を寄せ集めたつくりとなっていて、全体を見渡すのが難 しい。

#### ② 内容の一貫性

総論と各論が混在していて、たとえば USB 仕様書などのように一つの規格に特化したものと比べて読み通しづらい。

#### ③ 背景知識の必要性

ハードウェアや BIOS などの前提知識については解説していないことが多い。また、PnP BIOS、APM BIOS など、過去の類似規格からの歴史的な経緯や、PCI を筆頭に関連の深いバス規格を知らないと理解するのが困難。

そこで、ここでは ACPI というメカニズムの骨格となる重要な部分、言い換えるとパワーマネジメントとリソースコンフィグレーションの双方を ACPI の方式で実現するためのベースになるしくみに注目し、必要な情報を補足しながら解説します.

これにより、ACPIという世界に関して全体の見通しを良くしたいと思います。ACPI仕様書内でいうと、主として"4 ACPI HARDWARE SPECIFICATION"、"5 ACPI SOFTWARE PROGRAMMING MODEL(表1)"に対応しますが、必ずしもその記述内容を忠実に一つ一つ取り上げるわけではありません。

説明する順序としては、おおむね次のように考えています。

#### ① ACPI テーブル

ACPI 対応 BIOS がシステムボードに関する情報を収集・整理して OS に渡す ACPI テーブル群の規定.

#### ② ACPI の初期化

OSがACPIモードを有効にし、BIOSから渡された情報を用いてACPIネームスペースを展開していく処理。

#### ③ ACPIイベント

ACPI イベントを OS に通知するためのハードウェア的なしかけ(チップセットに実装されたレジスタ群など)とそのハンド

#### 〔表1〕ACPI仕様書の構成

| ACPI 規格のめざすゴールの提示                 |
|-----------------------------------|
| 用語の定義                             |
| ACPI を利用する典型的な事例の紹介               |
| ACPI を実現するためのハードウェア上のしかけ          |
| ACPI のゴールを達成するためのソフトウェア側のしくみ      |
| デバイスの列挙やリソースコンフィグレーションについての概要     |
| 個々のデバイスおよびシステム全体のパワーマネジメントについての概要 |
| プロセッサの省電力テクノロジの標準化                |
| システムスリープ/ウェイクの具体的な処理フロー           |
| ACPI が特別にケアするニッチなデバイスの取り扱いその他     |
| 電力の供給源すなわちバッテリおよび AC アダプタについて     |
| ファンおよび CPU スロットリングによる ACPI での放熱管理 |
| エンベデッドコントローラの役割と ACPI での通信方法      |
| SMBus の役割と ACPI での通信方法            |
| システムメモリのアドレスマップ取得方法など             |
| ASL言語リファレンス                       |
| AMLコードの厳密な定義                      |
| デバイス種別ごとのデバイス電力ステートに関する定義         |
| ACPI によるビデオカードの出力先制御や輝度調整などの補完    |
|                                   |

#### リング.

こうした基本事項を身に付けたあと、ACPIの管理下で達成される具体的な動作の中で、もっとも代表的な「スタンバイ」、「休止状態」(**図7**)など、システム全体のスリープ/ウェイクについて解説します。

また, ACPI 2.0 で新たに標準化されたプロセッサのパフォーマンス制御についても取り上げる予定です.

ACPI 2.0 では、インテルの最近のモバイル系プロセッサにおける SpeedStep や AMD 社 Athlon/Duron での PowerNow!, Transmeta 社の Crusoe での LongRun といったプロセッサ省電力テクノロジが新たに標準規格化され、ACPI のコンセプトにしたがい OS によるネイティブ制御の対象となりました.

#### ● ACPI 仕様書の入手方法

ACPI 仕様書は、ACPI オフィシャルサイト <sup>1)</sup>から入手が可能です. 現在公開されている最新版はバージョン 2.0b ですが、これは 2.0 のマイナアップデートなので、本稿では基本的に 2.0 を基準にします.

標準規格の仕様書という性格から、ACPI 仕様書の記述は かいまで、具体的にイメージすることが難しい場合があります。そのようなとき、ACPI 準拠のチップセットのデータシートをチップセットベンダの Web サイトから入手し、ACPI 仕様書での規定が実際のハードウェアでどのように実装されているのかを確認してみるとよいと思います。

また、ACPI 仕様書での用語の定義は、現実世界のハードウェアの実装の変化にともない、実態にあわせて少し読み換えるなど柔軟に解釈する必要があります。

なお、はっきりとアナウンスはされていませんが、今後 ACPI "3.0"が策定されていくときには、とくにハイエンドのサーバ機

#### 〔図7〕Windows XPでシステムスリープへの移行を選択



における高度なリソースコンフィグレーションを意識した内容や、ACPI 2.0 の段階ではまだ市場に出回っていなかったテクノロジで関連の深いもの(ハイパースレッディングやグラフィクスコントローラの省電力機能など)が ACPI 規格に取り込まれていくのではないかと思われます.

## **米 ACPI**テーブル

ACPI BIOS は、OS が ACPI 対応 PC を管理するために必要な情報を ACPI で規定されたテーブルの形式で提供します。テーブルには、プラットホームハードウェアに備わる ACPI レジスタなど基本的な能力について定義したものや、システムボード上のデバイスの論理関係 (ACPI ネームスペース) を表現し、個々のデバイスをコントロールする手順(コントロールメソッド) を記述したものなど各種存在します (表 2).

次に、そのうちのキーになるテーブルについて解説を加えて

#### 〔表 2〕ACPIの主要なテーブル

| テーブル名 | シグネチャ  | 詳細名称                                     | 役 割                                    |
|-------|--------|------------------------------------------|----------------------------------------|
| RSDT  | "RSDT" | Root System Description Table            | 他のテーブルの格納場所を OS に知らせる                  |
| FADT  | "FACP" | Fixed ACPI Description Table             | ACPI関連の基本的な能力を定義                       |
| FACS  | "FACS" | Firmware ACPI Control Structure          | OSと BIOS のハンドシェイクをとりもつストラクチャ           |
| DSDT  | "DSDT" | Differentiated System Description Table  | ACPIネームスペースの基盤                         |
|       |        |                                          |                                        |
| MADT  | "APIC" | Multiple APIC Description Table          | マルチプロセッサ構成での割り込みコントローラ (APIC)に関する設定その他 |
| ECDT  | "ECDT" | Embedded Controller Boot Resources Table | 起動時の早い時点でエンベデッドコントローラにアクセスする場合に<br>必要  |

#### いきます.

#### RSDP Structure と RSDT

ACPI テーブルのうち RSDT (Root System Description Table) は、ほかのテーブルの格納場所を OS に知らせる案内板の役割をもちます。

IA-32 の場合, OS は起動時にメインメモリの BIOS 領域内で RSDP(Root System Description Pointer) Structure をそのシグネチャである" RSD PTR "でサーチし、見つかった RSDP Structure 内から RSDT の物理アドレスを得ます(リスト 1).

こうしてアクセスが可能となった RSDT の末尾にある Entry



#### コラム2

### PC UNIX での ACPIへの対応

Linux 上での ACPI サポートは、現在 SourceForge の"ACPI4 Linux"プロジェクト (http://acpi.sf.net/)として、アクティブに開発されています。カーネル 2.5.x であれば、ACPI のコードは標準でツリー(drivers/acpi)に含まれていますが、最新版でテストしたいときは、同サイトからパッチをダウンロードして適用し、任意にコンフィグレーションしてカーネルを再構築します。

うまく再構築ができて、ACPI サポート状態でブートできると、/proc ファイルシステムに ACPI 関連のエントリが出現します。ACPI 経由でバッテリなどの情報を得たり、ACPI イベントの監視や、スリープステートあるいはプロセッサのパフォーマンスステートをコントロールするには、/proc/acpi 配下のエントリを操作します。

/proc/acpi インターフェースの詳細については、上述の "ACPI4Linux "SourceForge サイトの Documentation を参考にしてください、今のところ、一般のユーザーが/procファイルシステムを意識せずに済むようなユーザーランドのツールは、ごくシンプルなものしか出回っていません.

また Linux の場合, 本来の ACPI のコンセプトが, 現時点ではクリーンに実現されていないため, 一般にパワーマネジメント機能として期待されることを行うには, 別途, SwSusp: Software Suspend や, CPUFreq: CPU Frequency Driver といった別プロジェクトの成果物を必要とすることがあります.

残念ながら、こうした各プロジェクトの成熟度やインテグリティは、現時点では、とりわけノート型コンピュータのユーザーにとっては満足のいくものではありません。しかし、最近、IntelとRed Hat の間でもめていた AML インタプリタ部分についてのライセンス問題がデュアルライセンスという形で決着し、今後、Red Hat をはじめメジャーなディストリビュータが ACPI を標準サポートしていくことで、開発がよりいっそう促進されるものと思われ

#### ます.

●Intel/Red Hat, 専有技術とオープンソースの融合でライセンス 問題を解決

http://www.zdnet.co.jp/news/0302/18/nebt\_01.html なお、FreeBSDと NetBSD について、リサーチした範囲でごく 控えめにコメントしますと、どうやら両者とも、本文で言及している Intel ACPI CA サブシステムをうまく活用し、カーネルやデバイスドライバ部分は独自に発展させて、ACPI サポートを実現しているようです。

とくに FreeBSD は、日本の開発者が牽引して、Linux を上回る クオリティを達成していると聞きました。BSD 系の PC UNIX も 試してみたいとは思いつつ、今のところ利用経験がないため、今 回はこれ以上のコメントは差し控えておきます;-)

#### 参考文献

 ACPI-JP for FreeBSD のメーリングリスト http://www.jp.freebsd.org/acpi/ml-j.html

#### 〔図 A〕Linux カーネル再構築のようす



# ACPIによるPC/ATの電力管理とコンフィグレーション

フィールドは、他のテーブルへのポインタの配列となっており、 RSDT から各テーブルがたどれるようになります(**図8**).

なお、これらの ACPI テーブルは、通常、物理メモリの最上位の部分に展開されます。

#### FADT

RSDT がポイントするテーブルのうち、要となるテーブルが FADT (Fixed ACPI Description Table) で、プラットホームハードウェアが有する ACPI 関連の基本的な能力が定義されています

そこには、ACPIモードを有効にするために必要な情報や、ACPIイベントを OS に 通知 する SCI — System Control Interrupt という割り込みを入れる ACPI コアロジックのハードウェア上の実装に関する情報などが含まれています(表3).

そのほか、FADTは、FACS(Firmware ACPI Control Structure)、DSDT (Differentiated System Description Table) という二つの重要なアイテムへのポインタも含んでいます。

#### FACS

FACS は、OS と BIOS コードのハンドシェイクをとりもつ情報を含んでいます(表 4).

Waking Vector にはシステムウェイク時、OS に制御が戻った直後、リアルモードで実行されるコードが格納された物理アドレスがセットされます。

たとえば、RAMにコンテクストを保存してスリープ(Suspendto-RAM:  $S_3$ ) したシステムに対し、電源ボタンを押し下げなどのスリープ解除のイベントを発生させると、まずハード

ウェアレベルでシステムがウェイクアップし、CPU リセット後、BIOS の簡易初期化コードが走り、次に Waking Vector に ジャンプして OS の用意したコンテクスト復元用のルーチンに 制御が渡されます (**図 9**).

また、Global Lock は、OSのコードとSMIハンドラの双方によってアクセスされ得るハードウェア資源に対するアクセスの同期を取るために利用されます.

ACPI のコンセプトにおいては SMI への依存から脱却することが期待されますが、現実には ACPI 対応システムであっても、OS 実行中に SMI トラップが利用されることがあります。

#### DSDT

システムボード上で ACPI が管理するデバイスツリーおよび 個々のデバイスやイベントのコントロール手順を表現したテーブルが DSDT です.

DSDT がロードされた後に、別途副次的なテーブルやデータブロックを追加することもできますが、DSDT は起動時にロードされたあとはアンロードされることがなく、DSDT がすなわち ACPI ネームスペース全体を指すこともあります。

ACPIでは、プラットホームハードウェアの実装について ASL(ACPI Source Language) という専用の言語を用いて記述します。そして、この ASL をプラットホームに依存しない中間言語(バイトストリーム)に翻訳したものが、AML(ACPI Machine Language)です。DSDT は、AMLの形式で BIOS ROM に格納されています。

OS がランタイムで ACPI 関連処理を行う際には、ACPI サブ

#### 〔リスト 1〕DOS 窓で Debug コマンドを使って RSDP を見つけ,RSDT の格納位置を知る

```
C:¥> DEBUG

-S E000:0 Lffff "RSD PTR "

-S F000:0 Lffff "RSD PTR "

F000:7120

-D F000:7120 L24

F000:7120 (1)52 53 44 20 50 54 52 20-9E (2)43 51 50 55 42 20 02 (1)RSD PTR .(2)CQPUB .

F000:7130 (3)配 33 F7 1F 24 00 00 00-F8 33 F7 1F 00 00 00 00 .3..$....3......

F000:7140 9B 00 00 00

(1) RSDP Structure のシグネチャ

(2) OEM ID

(3) RSDT の物理ドドレス 0x1PF733CD
```

#### 〔図 8〕RSDP 構造体と RSDT およびその他のテーブル



# ひ 〇 ※

### 〔表 3〕FADT テーブルの主要フィールド

| フィールド名        | 備考                                                                |  |  |
|---------------|-------------------------------------------------------------------|--|--|
| FIRMWARE_CTRL | FACSストラクチャの物理アドレス                                                 |  |  |
| DSDT          | DSDT テーブルの物理アドレス                                                  |  |  |
|               |                                                                   |  |  |
| SCI_INT       | ACPI SCI 割り込みにアサインされた IRQ (8259 互換 PIC カスケード接続の場合)                |  |  |
| SMI_CMD       | SMI コマンドポート (I/O ポート) のアドレス                                       |  |  |
| ACPI_ENABLE   | ACPIモードを有効にする値                                                    |  |  |
|               |                                                                   |  |  |
| PM1a_EVT_BLK  | PM1a Event Register Block の I/O ポートアドレス (固定イベント用)                 |  |  |
| PM1b_EVT_BLK  | PM1b Event Register Blockの I/O ポートアドレス (固定イベント用)                  |  |  |
| PM1a_CNT_BLK  | PM1a Control Register BlockのI/Oポートアドレス                            |  |  |
| PM1b_CNT_BLK  | PM1b Control Register Blockの I/O ポートアドレス                          |  |  |
| PM2_CNT_BLK   | PM2 Control Register Blockの I/O ポートアドレス                           |  |  |
|               |                                                                   |  |  |
| GPE0_BLK      | General-Purpose Event o Register Block の I/O ポートアドレス (汎用イベント用)    |  |  |
| GPE1_BLK      | General-Purpose Event 1 Register Block の I/O ポートアドレス (汎用イベント用)    |  |  |
| •••           |                                                                   |  |  |
| P_LVL2_LAT    | プロセッサが C2 ステートに遷移するときのレイテンシ(マイクロ秒). 100 より大きい場合は C2 はサポートされない     |  |  |
| P_LVL3_LAT    | プロセッサが C3 ステートに遷移するときのレイテンシ (マイクロ秒). 1000 より大きい場合は C3 はサポートされない   |  |  |
|               |                                                                   |  |  |
|               | システムで固定の各種フィーチャーの有無を表すフラグ                                         |  |  |
|               | ・フィーチャーの例                                                         |  |  |
| Flags         | キャッシュをフラッシュしてメモリのコヒレンシを維持する WBINVD 命令のサポート<br>プロセッサの C1 ステートのサポート |  |  |
| rage          | ボタンデバイスの実装形態                                                      |  |  |
|               | RTCアラームによるシステムスリープ解除のサポート                                         |  |  |
|               | ドッキングステーションのサポート                                                  |  |  |

#### 〔表 4〕 FACS 構造体の主要フィールド

| フィールド名                 | 備考                                                            |
|------------------------|---------------------------------------------------------------|
| Hardware Signature     | 直近の起動時に BIOS によって記録され、S4(休止状態) からの復帰時にディスクに退避されたイメージの正当性評価に使用 |
| Firmware_Waking_Vector | システムウェイク時に OS に制御が戻った直後、リアルモードで実行されるコンテクスト復元用ルーチンが格納された物理アドレス |
| Global_Lock            | OSのコードと、SMIハンドラの双方によってアクセスされ得るハードウェア資源へのアクセスを同期させるグローバルロック    |

### 〔図 9〕BIOS による初期化



# ACPIによるPC/ATの電力管理とコンフィグレーション

システム内に実装された AML インタプリタを呼び出して, ACPI BIOS から提供された AMLコードを解釈し, ACPI タス クを実行していきます。

#### ▶ DSDT のダンプ

インテルが無償で公開している ASL コンパイラ <sup>2)</sup> を使って, ユーザーが自分の PCの DSDT をダンプすることができます.

ASL コンパイラは、本来は BIOS エンジニアが ASL コードを AML に変換するために使うものですが、 AML を逆アセンブルする機能も追加され、 Windows/Linux どちらの環境からでも使用中のマシンの DSDT のダンプができるようになりました (リスト 2).

ASLマクロなどもきちんとデコードして、オリジナルに近いフォームに整形してくれるので解読が容易です。

• ACPIネームスペースに含まれるデバイス

#### ▶ \_HID ベースのデバイス

システムボード上には、デバイスの列挙とパワーマネジメントの手段が、自身のバス規格で定められていないレガシーなデバイスも存在します.

こうしたデバイスのコントロール手順を標準化するのも ACPI の役割の一つで、対象となるデバイスは DSDT に記述され、ACPI ネームスペース内で\_HID(Hardware ID) オブジェクトにより識別されます。

**リスト3**(pp.187-188)の  $89 \sim 131$  行目に、サンプルとしてシリアルデバイスの定義例を示します.\_HIDをもつデバイス配下に記述される、オブジェクトおよびコントロールメソッドについてコメントを付けてあります.

OS は ACPI サブシステムを用い、ASL コントロールメソッドを介して\_HID ベースのデバイスを直接列挙し、リソースを割り当て、OS が内部で管理しているデバイスツリーに組み込みます。

デバイスのパワーマネジメントも、同じく ACPI が ASL コントロールメソッドに記された手順を実行し、直接コントロールします.

#### ▶ \_ADR ベースのデバイス

これに対し、PCI/USB/CardBus/IEEE1394 など、自身のバス規格のなかでデバイスの列挙/リソースコンフィグレーションやパワーマネジメントの取り扱いが規定されているデバイスは、ACPIが直接管理する必要はありません。

プラグアンドプレイが汎用的にサポートされたバス規格では、どのデバイスがシステムに追加されるかあらかじめ予測することができず、おのずと ACPI ネームスペースの範囲外となります。

こうしたデバイスについては、OS がシステムワイドで統 なルールに基づき、標準バスの規定を実現するバスドライバと、バス上の各デバイス用に用意されたデバイスドライバを利用してハンドルします。

ただし、これらの標準バス規格に準拠したデバイスであって

#### [リスト2] iasl-hと iasl-d による DSDT ダンプのようす

```
// ここでは,Windows 上からシステムの DSDT をディスアセンブルするようすを
..
// 紹介します
C:¥> iasl -h
ACPI Tables and AML Disassembler:
                          // ディスアセンブル機能に関係するオプション
  -d [file]
              Disassemble AML to ASL source code file (*.dsl)
  -dc [file]
              Disassemble AML and immediately compile it
              (Obtain DSDT from current system if no input file)
  -g
              Get ACPI tables and write to files (*.dat)
C:¥> iasl -d
Intel ACPI Component Architecture
ASL Optimizing Compiler / AML Disassembler version 20030122
                                                 [Jan 22 2003]
Copyright (C) 2000 - 2003 Intel Corporation
Supports ACPI Specification Revision 2.0b
DSDT obtained from registry, 27178 bytes
  // Windows の場合, ACPI BIOS の内容をレジストリにコピーしたものが
  //ディスアセンブルの対象
Table [DSDT] written to "DSDT_SAMPLE.dat"
Disassembly of DSDT
Pass 1 parse of [DSDT]
Pass 2 parse of [DSDT]
Parsing Deferred Opcodes (Methods/Buffers/Packages/Regions)
Parsing completed
Disassembly completed, written to "dsdt_SAMPLE.dsl"
   コメントやマクロの記述方法を除けば、内容は ACPI BIOS に
  // 格納されているものと同一
```

も、システムボード上に常駐し、その制御に自身のバス規格で 定められた以外の、付加的な設定情報を必要とするものがあり ます。

PCI デバイスの割り込みルーティングの設定は、その代表的なケースになります。

そのほかにも、たとえば標準バスのホストコントローラが、 PCIの PME# や USB のリモートウェイクアップのように、自 分が管理するバス上のデバイスから届けられたシステムスリー プ解除のシグナルを ACPI レジスタにルーティングするための 設定情報なども、これに該当します.

このような付加的な設定情報を追加するには、まずそのデバイスを DSDT に含め、自身のバス上での位置関係を示す\_ADR (Address)オブジェクトによって ACPIネームスペース内で識別されるようにしておきます.

これにより当該デバイスの存在を ACPI に知らせ、ACPI に 制御を補ってもらうことができます。

そして、前述の PCI 割り込みルーティングであれば、\_PRT (PCI Routing Table) という割り込みルーティング情報を定義したテーブルを記述します.

リモートウェイクのケースなら, \_PRW (Power Resource for Wake) を定義して、シグナルをルーティングする ACPI レジス

# ひ 〇 ※

タ内のビット位置を明確にします.

チップセットに統合された各バス規格のホストコントローラデバイスは、ほとんどの場合、上述のような理由により DSDT に含めます.

また、ドッキングステーションの拡張ボード側に内蔵された デバイスも DSDT に含めることが普通です。

最近では、USB ルートハブや USB ポートを DSDT 内に記述 するケースもよく見かけます。

**リスト3**に、\_ADR をもつデバイスの例として、Host-to-PCI ブリッジ (16 行目以下) と、その下にぶら下がる USB ホストコントローラ (35  $\sim$  83 行目) を取り上げています.

### 米 ACPIの初期化

OSの起動過程で、ACPIサブシステムは、上述のACPIテーブルをロードしていきます。ロードしたテーブル情報は、内部で定めた構造にマップし、この後のOS側での利用に備えます。

また、ACPI 対応システムであっても、ACPI 非対応 OS との 互換性などの理由で SMI と SCI の双方の割り込みメカニズムが サポートされている場合は、システムを ACPI モードにする作

#### 〔図 10〕 ACPI の初期化のフロー



業が発生します.

ACPI モードでない場合、プラットホームハードウェア上で 発生したパワーマネジメント関連イベントは、OSからは透過 的な SMI で通知され、OSから「見えない」モードでハンドルさ れます。

一方、ACPIモードでは、プラットホームハードウェア上で 発生した ACPIが管理すべきイベントが、SCIによって「ACPI イベント」として OS に通知されるようになります。

このような ACPI の初期化の流れを図 10 に示します.

#### ACPIモードへの移行

この作業は、FADT内のACPI\_ENABLEフィールドの値をSMI\_CMDフィールドで指定されたSMIコマンドポートに書き込むことで実現されます。

**ACPI** サブシステムは、**FADT** 内の PM1a\_CNT\_BLKフィールドが指す PM1 Control Registers の SCI\_EN ビットを確認し、正しく **ACPI** モードに移行できたかを判定します (**表5**).

SCI\_ENビットがセットされていれば、システムは ACPIモードにあり、ACPIイベントは SCIを発行する回路にルーティングされ、OSから「見える」モードでハンドルされます。

なお、SCI は原則として共有可能なレベルトリガの割り込みで、極性はアクティブローです。 典型的な IA-32 シングルプロセッサ環境で、割り込みコントローラが 8259 互換 PIC カスケード接続の場合、ほかの PCI デバイスと IRQ を共有することもあります。

### ● ACPIネームスペースの展開

続いて ACPI サブシステムは、ACPI ネームスペース全体を解析し、ASL コード内に定義された各種オブジェクトやバッファを初期化して、ACPI タスクが AML インタプリタによって実行できる作業環境を整えていきます。

AML インタプリタ実行の用意ができると、ACPI サブシステ

〔表 5〕PM1 コントロールレジスタ

| 1.8 1 | ビット フィールド名 コメント |                                                                                                 |  |
|-------|-----------------|-------------------------------------------------------------------------------------------------|--|
| ピット   | フィールト名          | コメント                                                                                            |  |
| 0     | SCI_EN          | このビットがセットされていれば、システムは $ACPI$ モード、プラットホーム上の $ACPI$ イベントは $SCI$ として $OS$ に「見える」モードで通知 される         |  |
| 1     | BM_RLD          | プロセッサが C3 ステートに落ちているときに,<br>このビットがセットされていると, バスマスタ<br>要求の発生によってプロセッサは Co に戻る                    |  |
| 2     | GBL_STS         | write-only で、OS側がGlobal Lockをリリース<br>する場合にセットする                                                 |  |
|       |                 |                                                                                                 |  |
| 10~12 | SLP_TYPx        | システムスリープの際に,実際に移行するシス<br>テムステートを示す値を書き込む                                                        |  |
| 13    | SLP_EN          | システムスリープ移行のソフトウェア的な準備が完了した時点で、このビットをセットすることで、SLP_TYPxにプログラムしたシステムステートへ実際に落ちるハードウェア的なシーケンスが開始される |  |
|       |                 |                                                                                                 |  |

# ACPIによるPC/ATの電力管理とコンフィグレーション

ムは、オブジェクトの評価やコントロールメソッドの実行を開始します.

このステージでは、OS は ACPI を利用して、じつにさまざまな作業を行います。

ACPIネームスペースを母体にして、OSが内部で管理しているシステムワイドなデバイスツリーを展開する作業も、この段階で成されます. \_HIDで識別されるデバイスは、OSがACPIを利用して直接列挙し、リソースを割り当て、OSのデバイスツリーに組み込みます。また、\_ADRをもつデバイスに対して、その制御を補完するための準備をしていきます。

#### • オペレーション・リージョン・ハンドラ

ACPIでは、ASLコードから I/O ポートやシステムメモリ、 PCIコンフィグレーション空間といった領域にアクセスするために、オペレーション・リージョンを定義し、これを経由して 仮想的にハードウェア資源にアクセスします。

実際のハードウェアをアクセスするには、たとえば PCI コンフィグレーション空間内に定義したオペレーション・リージョンであれば、 PCI バスドライバのような、対象領域のアクセスに関する知識をもったレイヤを利用する必要があります。

AML インタプリタと、こうした ACPI サブシステム外部のレイヤとの間を取り持ち、ASL によるオペレーション・リージョンへのアクセスを可能にする仕事を受け持つのがオペレーション・リージョン・ハンドラです。

対象領域の性質によっては、初期化時にオペレーション・リージョン・ハンドラを登録し、ASLコードからのオペレーション・リージョンへのアクセスに備えておく必要があります。

以上、ここまで解説してきた事項を**リスト3**のサンプルコードをベースに整理しておきましょう。**リスト3**を見てください。

#### ▶ PCIルートの取り扱い

まず 16 行目に、システムバスのスコープ内で、Host-to-PCI ブリッジが、PCIo という名のデバイスとして定義されています。 そして、17 行目の\_HID オブジェクトで、自分自身の PnP ID が PNPoAo3 (PCI バス) であることを OS に知らせています。 OS 側のデバイスツリー内での Host-to-PCI ブリッジ= PCI ル

ートの扱いは、各 ACPI 対応 OS の設計上のポリシーによるところです。

Windows XPのWDMデバイスツリーを例に取ると、ACPIドライバが管理するPDO(Physical Device Object:バス上のデバイス列挙の責任を負う)に、PCIドライバが作成したFDO(Functional Device Object:そのデバイス本来の機能を果たす)がぶら下がって、Host-to-PCIブリッジ用のデバイススタックを構成しています。

**図11**は、このようすを Open Systems Resource, Inc.社のデバイスツリーユーティリティで表示しているところです。

デバイスツリーユーティリティは、Windows XPの DDKに 付属しているほか、Open Systems Resource, Inc.社のサイト <sup>3)</sup> から単独でダウンロードすることもできます.

#### 〔リスト3〕サンプル ASL コード

```
1:Scope(Y SB) {
3: Device (LNKA) {
       Name ( HID, EISAID ("PNPOCOF"))
                                // PCI 割り込みリンク仮想デバイス
 5:
 6:
       Name (_PRS, ResourceTemplate () {
         // PCI 割り込みリンク仮想デバイス LNKA に割り当て可能な IRQ
7.
8:
         IRQ (Level, ActiveLow, Shared) {3,4,5,6,7,9,10,11}
       3.)
9 -
       Method (_DIS, 0, NotSerialized) {...}
10:
       Method ( CRS. O. NotSerialized) { ... }
11:
         // 現在割り当てられて IRQ
       Method ( SRS, 1, NotSerialized) { . . . }
12:
         // 有効な IRQ を LNKA に割り当てるメソッド
13: }
14:
15:
16: Device(PCIO) {
17:
       Name(_HID, EISAID ("PNPOAO3")) // PCI バス
       Name(_ADR, 0x0) // デバイス 0, ファンクション 0
18:
19:
       Name(BBN, 0x0) // PCI パス 0
20:
21:
       // PCI Routing Table
22:
       Name (_PRT, Package (0x06) {
           // この PCI ルーティングテーブルには 6 個のエントリが存在
23:
           // PCI バス 0, デバイス 0x1D の INTA は、
24 .
           // PCI 割り込みリンク仮想デバイス LNKA
25:
26:
           // に現在割りあたっている TRO ヘルーティングされる
27:
           Package (0x04) { 0x001DFFFF, 0, ¥ SB.LNKA, 0x00 },
28:
29:
30:
                : // 以下, 省略
       })
31:
32:
33:
34:
35:
       Device(USBO) { // USB ホストコントローラ
           Name ( ADR, 0x001D0000)
             // PCI バス 0, デバイス 0x1D, ファンクション 0
37:
38:
           // USB ホストコントローラの PCI コンフィグ空間内で、
39:
           // オフセット 0xC4 から 0x4 の長さぶん, USBR という
// 名前のオペレーション・リージョン --- ここでは USB
40:
41:
           // Resume Enable Register がマップされていると仮定
42.
           // --- を定義
43:
44:
           OperationRegion (USBR, PCI Config, 0xC4, 0x04)
45:
           // USBR のベースから 2 ビット分を RSEN フィールド ---
46:
           // ルートハブの 2 つのポートからの Wakeup Event を
47:
           // 通知する PORTOEN, PORTIEN ビットをマップ
48:
49:
           // していると仮定 --- として定義
50:
51:
           Field(USBR, DWordAcc, NoLock, Preserve) {
52:
53:
           // Power Resource for Wake
           Name (_PRW, Package (0x2) {
56:
               // USB ポートからの Wakeup Event をルーティングする
57:
58:
               // ACPI 汎用イベントレジスタのビット位置
59:
60.
               0×03
               // USB ポートからの Wakeup Event によって S3 状態
61:
               // のシステムをウェイクアップすることが可能
62:
63:
               11
64:
               0 \times 03
           })
65:
66:
           // Power State Wake --- このデバイスからシステム
67:
           // スリープを解除できるようにするかどうか設定
68:
69:
           Method (_PSW, 1, NotSerialized)
70:
71:
72:
               If (Arg0)
                 // 引き数が 1 なら, スリープ解除機能を有効にする
73:
                                                 (次頁につづく)
```



#### (リスト3) サンプル ASL コード(つづき)

```
Store (0x03, RSEN)
                     // USB Resume Enable Register O PORTOEN,
                                        PORTIEN ビットをセット
 75:
 76.
               Else // 引き数が 0 ならスリープ解除機能を無効にする
 77.
78:
                   Store (0x00, RSEN)
                     // USB Resume Enable Register O PORTOEN,
                                        PORTLEN ビットをクリア
 79.
 80:
 81:
82:
 83:
 84:
        Device (ISAB) { // PCI-to-ISA ブリッジ
 85:
86:
           Name ( ADR, 0x001F0000)
               // PCI パス O. デバイス Ox1F, ファンクション O
 87:
           89:
 90:
              // デバイス識別のための情報
              Name (_HID, EISAID ("PNP0501"))
91:
              // 16550A 互換 シリアルポート
 92.
              // デバイスのステータスに関する情報
 93.
              Method (_STA, 0, NotSerialized) {...}
94:
              // デバイスの有効/無効, 取り外されているかなど
                                           ステータスをレポート
95:
              // デバイスへのリソース割り当てに関するコントロール
96:
                                               メソッドその他
              Name ( PRS, ResourceTemplate ()
97:
              // 割り当て可能なリソースのいくつかの組み合わせを返す
98:
                    ′ 互換性およびパフォーマンス上のいずれにおいても
99:
100:
                  // 最適なリソース割り当てパターン
102:
                  StartDependentFn (0x00, 0x00)
103:
                     IO (Decode16, 0x03F8, 0x03F8, 0x01, 0x08)
104:
                               // IO ポート 0x3F8 から 8 バイト
105.
                      IRQNoFlags () \{4\} // IRQ 4
106:
                  }
107.
                  // 互換性の点からは受け入れ可能で、パフォーマンス
108:
109.
                  // 上は最適なリソース割り当てパターン
110:
111:
                  StartDependentFn (0x01, 0x00)
112:
                     IO (Decode16, 0x02F8, 0x02F8, 0x01, 0x08)
113:
                       // IO ポート 0x2F8 から 8 バイト
                      IRQNoFlags () {3} // IRQ 3
114:
                  }
115:
116:
117:
118:
                  EndDependentFn ()
120:
              Method (_CRS, 0, NotSerialized) {...}
121:
                // 現在割り当てられているリソース情報を返す
              Method (_SRS, 1, NotSerialized) {...}
122:
                // リソースを実際に割り当てる
123:
              Method (_DIS, 0, NotSerialized) {...}
                // デバイスを無効にし、リソースを開放する
124:
              // デバイスステートの設定手順を伝えるコントロールメソッド
125:
              Method (_PSC, 0, NotSerialized) {...}
126:
                // 現在のデバイスステートを返す
127:
              Method ( PSO, 0, NotSerialized) { . . . }
                // デバイスステートを DO にセットする
              Method (_PS3, 0, NotSerialized) {...}
128:
                // デバイスステートを D3 にセットする
130:
131:
          }
132:
133:
```

#### 〔図 11〕 DeviceTree.exe の PCI FDO の部分



18 行目の \_ADR は、PCIo デバイスの PCI バス上でのアドレスを表現しています.Host-to-PCI ブリッジなので、アドレスはデバイス 0、ファンクション 0 です.

19 行目の\_BBN は、ホストバスに複数の Host-to-PCI ブリッジが対等に接続されたマルチ PCI ルート構成のシステムにおいて、BIOS が割り当てたシステム内で一意の PCI バス番号です。

#### ▶ PCI 割り込みルーティング

このサンプルでは、システムバス直下の  $3\sim13$  行目に、LNKA という PCI 割り込み用の IRQ をプールする仮想デバイスが定義されています。ここでは割愛していますが、通常はこのような PCI 割り込みリンク仮想デバイス (リンクノード) が複数定義されているはずです。

PCI の割り込みは、レベルトリガで共有可能といっても、OS の割り込み処理の機構によっては、あまり多数の割り込みがチェーン化していると、パフォーマンス上のペナルティも無視できません。

そこで、OS はパフォーマンスへの影響などを考慮しながら、 PCI 割り込みリンク仮想デバイスへ、ACPI コントロールメソッドを介して実際の IRQ を割り振っていきます。

PCIo配下の\_PRT(22行目)では、PCIバスo上に存在する各デバイスのINTA~INTDを、どのPCI割り込みリンク仮想デバイスへルーティングするかを定義しています。サンプルでは割愛しましたが、やはり通常はこうしたエントリが複数個きちんと定義されていて、デスクトップのPCI拡張スロットにも対応できるようになっています。

このようにして、ACPI 対応システムでは、従来 BIOS ROM に含まれるシグネチャ" \$PIR "の PCI 割り込みルーティングテーブルで実現していた PCI 割り込みのルーティングを、ACPI による方法で置き換えています.

#### ▶ USB デバイスによるリモートウェイクアップ

次に、PCIバスo上に存在し、\_ADRベースでUSBoという名前で定義されているUSBホストコントローラについて見ていきましょう.

36 行目の ADR により、自分は PCI バス 0、デバイス 0x1D、

# ACPIによるPC/ATの電力管理とコンフィグレーション

ファンクション 0 であることを表現し、次いで44行目ではPCI コンフィグ空間内のオフセット 0xC4 から4バイトを、USBR と いう名前のオペレーション・リージョンとして定義しています。

このサンプルは、インテルの ICH 系統のチップセットを参考 にしていて、USB UHCI ホストコントローラの PCI コンフィグ 空間のオフセット oxC4~には、USB Resume Enable Register がマップされていると仮定しています。

 $51 \sim 53$  行目では、今度は USB Resume Enable Register を マップした USBR オペレーション・リージョン内のベースから 2 ビット分を RSEN フィールドとして定義しています.

この二つのビットは、USBルートハブの二つのポートからの Wakeup Event 通知を有効にする PORTOEN、PORT1EN ビット をマップしていて、これらをセットすることにより、リモートウェイクアップの通知が可能となります。

56行目からの\_PRWでは、まず最初のエレメントで、USBホストコントローラに到達したリモートウェイクアップシグナルをルーティングする ACPI汎用イベントレジスタのビット位置を明確にしています。

\_PRWの二つめのエレメントは、そのデバイスからの Wakeup Event によって解除可能な、もっとも深いシステムスリープステートを示しています。ここでは値が 0x3 なので、USB0 の下に接続された USB インプットデバイスのリモートウェイクアップシグナルで、S3 システムスリープを解除できることがわかります。

70 行目の\_PSW (Power State Wake) は、デバイスが備えるシステムスリープ解除機能を有効/無効に設定するメソッドです.

引き数が1なら、スリープ解除機能を有効にします。なお、サンプルでは、USB Resume Enable Registerの PORToEN、PORT1EN ビットをマップした RSEN フィールドに ox3 をストアして、両ビットをセットしています。

引き数が o なら、スリーブ解除機能を無効にします。サンプルでは、今度は RSEN フィールドに oxo をストアして、両ビットをクリアしています。

#### ▶ \_HID デバイスの列挙

続いて、シリアルデバイスを例にして、\_HIDベースのデバイスを OS が列挙するようすを見ていきます.

89 行目を見てください. このサンプルでは, シリアルデバイスはチップセット内蔵の PCI バス上に存在している PCI-to-ISA ブリッジの下にぶら下がっていることを想定しています.

この物理的なトポロジを反映して、ACPIネームスペース内では、シリアルデバイス COM1が、フルパス $Y_SB.PCI0$ . ISAB. COM1 に位置しています.

ACPI ネームスペースのパス表記は、見てのとおり、非常にシンプルです。上の例では、仮想的なシステムバスの下に Host-to-PCI ブリッジを表す PCIO が置かれ、この PCI バス上に PCI-to-ISA ブリッジである ISAB があり、シリアルデバイス COM1 はその下にあることが表現されています。

また ASL コード内で、各オブジェクトのスコープがはっきり しているときには、相対パス表記も広く使用されます。

さて、すでに述べたように、\_HIDで識別されるデバイスは OSによる列挙を必要としています.

この例では、OS は、ACPI を利用してデバイスを列挙した後、127行目の $_PSO$  メソッドを実行して、デバイスステートを DO にセットします。

\_PSO メソッドは、シリアルデバイスを DO にセットするため のレジスタアクセスをラップしているので、ACPI としては、 \_PSO メソッド内の各ステートメントさえ実行していけばよい ことになります.

D0 にセットするのと同時に、ACPIは 97 行目の\_PRS オブジェクトを評価して、デバイスに割り当て可能なリソースの組み合わせの情報を得ます。

サンプルにあるように、ACPI BIOS側では、リソース割り 当てパターンに優先度を付けてレポートすることができます。

OS は、これらの中から、ほかのデバイスと衝突のないものを選択し、122行目の\_SRS メソッドを実行して、実際にリソースをデバイスに割り当てます。

\_SRSメソッドに、ACPIで規定されたフォーマットで、設定したいリソースの情報を渡しさえすれば、あとは\_SRSメソッド内の各ステートメントを実行することにより、リソースの設定が完了します。

このように、デバイスに対して何かを設定するタイプのコントロールメソッドは、基本的にレジスタアクセスをラップしているという点で、類似のしくみになっています。

OSは、最後に94行目の\_STAメソッドを実行して、デバイスのステータスが適切に設定されているか確認しておきます。

### おわりに

今回は、ACPIの基本事項のうち、代表的な ACPI テーブル群と、システム起動時の ACPI サイドの初期化プロセスまでを見てきました。

ここでしばらく、「休止状態」に入って英気を養い、次回は、 ACPIイベント機構の解説から、本稿を「レジューム」したいと 思います。

#### 参考文献,URL

- 1) ACPIオフィシャルサイト, http://www.acpi.info/
- 2) Intel ASL コンパイラ/AML ディスアセンブラ,

http://www.intel.com/technology/IAPC/acpi/downloads.htm

3) Open Systems Resource, Inc. デバイスツリーユーティリティ V2.10, http://www.osr.com/files/devicetree\_v210.zip

あだち・けんいち



#### アトムの時代がはじまった

2003年の4月初旬、世界最大のロボット博覧会であるROBO DEX2003が横浜で開催された。ホンダのASIMOが歩いて会場に登場し、ソニーのAIBOは新体操のリボンを披露していた。じつは今回のROBODEXは、アトムの誕生にちなんで行われたヒューマノイドロボットのデモンストレーションだったようだ。それもあって、プレス会場では、アトム誕生の直前までを見せてくれた。誕生の直前というのがちょっと残念だったが、ROBODEXの最終日がアトムの誕生日の前日だということで、誕生するところまで見せて歴史を変えてしまってはいけないという日本人らしい配慮だろう。

そんな日本が、世界でもっともヒューマノイドロボットの研究開発に熱心な国らしい。それは、「アトム」を愛した国だからだとロボット開発の第一人者たちは声をそろえていう。それほどアトムの影響は大きい。

しかし、ヒューマノイドロボットがアトムの域に達するのはまだまだ先で、30年から50年を目標にしたいと専門家は語っている。だが、技術の進歩は概して予想より早い。新しい発明や発見が技術の進歩を急激に進めたり、偶然が大きな障害を気に解決させていくということを、過去の科学技術の発展の歴史が物語っている。アトムが地上に現れるのも、もしかしたらそんなに遠いことではないのかもしれない。

ROBODEX 会場の続きは、翌日の兵庫県の手塚治虫記念館で見ることができたそうだ。午前10時半になったとき、ベートーベンの交響曲第5番「運命」が流れ、展示されていたアトムが地上に生を受け、起き上がってメッセージを伝えると、まわりから歓声が上がったそうだ。最初、アトムが話す予定はなかったが、多くの人から要望が寄せられていたため、急遽メッセージを伝えることにしたという。

#### ヒューマノイドは神への冒涜だ!

ところで、ヒューマノイドは神への冒涜だと非難する人がいる。その主旨は、次のようなことだ。

神は自らにそっくりな人間を創造した。しかしサルトル、ニーチェ以降、人間は神の存在を否定し、自然環境を破壊、遺伝子を操作し、人間を神とする宗教までをも生み出した。傲慢になった人間は、今度は自らを最終的なゴールとしたロボットを

作ろうとしている。これは、神への冒涜以外の何ものでもない。 哲学者然とした方々のいうことはよくわからないし、神への 冒涜であるかどうかは、この際どうでもいいようか気もするが

冒涜であるかどうかは、この際どうでもいいような気もするが、 開発が無制限に進むことに対する警鐘とも受け取れば、公害を 見てきた世代としては、理解できなくはない。

その一方で、ヒューマノイドロボットは不要だと断言する人もいる。その論理によれば、ヒューマノイドは投資効果に見合うだけの働きが期待できない。それでも騒がれているのは、単に希少な見世物としてのみ価値があるからだ。たとえ将来、大量生産され、安価で誰でも手に入る『道具』になったとしよう。道具にするためにロボットを使うならば、道具をロボットにしたほうが使い勝手がよく、安上がりだ。たとえば、ロボットを介護ベットで働かせるなら、介護ベッドをロボットにしたほうが合理的だということだ。

この種の議論は、筆者が知る限り、20年以上の間繰り返されてきたような気がする。しかし、この論理は誤っている。たしかに人間は万能の神を超えることはできないが、ある肉体的、精神的な特殊技能において、神にまでも近づく最高の技能——ある人はそれを芸術的と呼ぶかもしれない——を身に付けることができる。その最高の技能をロボットに実現させ、より多くの人々に、より長い間、人間をサポートすることができれば、人間の幸せを実現するために大きな価値が生まれるはずだ。

しかし、条件がある。人間らしさをもってこそ、ヒューマノイドの意義がある。人間と一緒に行動し、自らの感情を積極的に人間に伝え、人間の気持ちを理解することで、はじめて人間と共感でき、本当の意味で人間をサポートできるからだ。

#### • 人間らしさの価値はどこにある

印鑑ロボット、寿司ロボットなど、単純作業を効率的に繰り返すだけならば、産業用ロボットでも十分だ。人間が寝ている間も、ただひたすら効率的に仕事をこなして結果を上げればいい。SP、ガードマンロボット、救助ロボットなども、別にヒューマノイドでなくてもいいかもしれない。目的の機能を実現することが最優先だからだ。

しかし、人間の輪の中に入るとすれば、人間との会話による 滑らかなコミュニケーションが必要だ。産業ロボットでは、使 用する人間側に一方的にストレスが溜まる。物いわぬ機械が思



うように動かないときに蹴飛ばしたくなる,あの気持ちだ.

ネコ型ロボットのドラえもんは、のび太をあるときはやさしく見守り、あるときは厳しく教育している。のび太の家族も、そしてTVを見ている我々もこれを自然に受け止めていられるのは、ドラえもんが人間らしさがある超人(?)だからだ。

生涯の伴侶を失った一人暮らしのお年寄りや、重度の身体障害者をあらゆる面でサポートできる介護ロボットがあれば、その価値は高い。人生に疲れた自殺志願者には、精神科医なみに心の闇を打ち砕いてくれる、お友達ロボットが必要かもしれない。辛抱強く、いつでもどこででも付いて来てくれ、一緒に笑い、そして泣き、話し相手になってくれる。そのため、ヒューマノイドロボットの人間らしさに大きな価値がある。

これを実現するためにも、心理学者、言語学習、医学者、介護研究者、教育家などの各方面の専門家との共同研究も推し進められるべきだろう。

#### • ヒューマノイドエンジニアロボット

思うに、技術者ロボットというのもあるかもしれない。たとえば、最新技術や技法をす早く学習し、技術者にレクチャしたりする。初心者や年をとった覚えの悪い技術者にも、辛抱強く教えることができればいい。これが人間だったら、申し訳ないと思って遠慮してしまうこともあるが、人間でないわけだから、いくらでも聞ける(このへんに「人間らしさ」の微妙な線引きが必要なのだが)。

開発に直接参加して大きな力になるかもしれない. 会話インターフェースを備え, 人間と打ち合わせしながら数倍のスピードで開発を進めることができると大きな価値がある.

そうなると、ロボットが新しい技術の空洞化を生み、人間が 技術をなくしてしまう問題がおきるかもしれない。しかし、パ ソコンが普及して、漢字を書けなくなったからといって、パソ コンの文化を否定する人はいないだろう。なぜならば、人間は パソコンを利用して、さらに高度な能力が要求され、それを実 現できるように進化していったからだ。

ロボットには、プロトタイプ開発やコーディング、テスト、 1次サポートなどの労働集約的作業をやってもらえばいい.人間はマーケティング、企画、設計、顧客サポートなどに、より高度な作業に力を入れることができるようになるはずだ.



#### ● 日本のロボット工学に金字塔を

最後に一つ、大きな問題が残る。それは、価格の高さである。 どんなに大量生産されても、やはりかなり高価なものになるだろう。だがリース契約にすれば、人間に給料を払うのと同じくらいの金額になるかもしれない。また、文化的、福祉的分野においては、公共支援の可能性もあるだろう。将来の公共予算は、一般家庭や企業おいて人間と一緒に暮らし、技術や生産性を高め、ゆとりをもたらすヒューマノイド型ロボットにしてもらうべきだ。

筆者には一つの夢がある。ヒューマノイドロボット工学を制して、日本が再度世界のトップに立つことだ。最近、日本もノーベル賞をとることのできる科学者が多く登場するようになった。世界一といわれる日本のロボット工学の研究者の中から、多くのノーベル賞の受賞者を出し、金字塔を打ち立ててほしい。そんなに大きな夢物語ではない気がするのだが。

**あさひ・しょうすけ** テクニカルライター イラスト 森 祐子

# Engineering Life in

### ビジネススキルを修行しながらエンジニアを続ける

#### ■今回のゲストのプロフィール

羽田直樹(はだ・なおき): 1995年, 電気通信大学卒業後, インターネット関連のプロジェクトのために渡米した。その後は Web のバックエンドを専門に扱う。仕事もビジネスも友達も妻も, インターネット経由で獲得. Adobe Systems, Inc.では, 1998年よりインターネット関連の製品に関わり, 最近 Photoshop チームに移籍。週末はオフロードバイクで野山を駆け回る。『金持ち父さん、貧乏父さん』と『非常識な成功法則』に感化され、エンジニアを続けながらビジネスと投資のスキルも修行中。メールアドレスは, naoki@hadaseicha.com

### ☆ 日本のバイト先からの紹介で渡米する

▶=→ 本職以外にもいろいろと活動されているそうですが、 まずはアメリカに来られたきっかけからお願いします。

羽田 日本でプログラマのバイトをしながら夜間の大学に 通っていたのですが、卒業したらアメリカで働けたらいいなぁ、 と仲間と話していたのがきっかけです。私はバイクが好きなの で、天気がよくて高速道路の多いカリフォルニアのような環境 が良いな、とか思っていました。また、コンピュータが発明さ れた国に行くことも大事だと思っていました。

そこで移住する方法を調べようと市役所や都庁に問い合わせてみたりもしましたが、あまりわかりませんでした。今度は、いろいろな著書を調べているうちに、どうやらビザをスポンサーしてくれる雇い主が必要であることに気がついたのです。たまたまバイトの面接に行った会社でアメリカに関連会社があるから協力できるといってくれました。そして夏休みにとりあえず下見を兼ねて一度行ってみて、1年後にそこの知り合いの紹介でアメリカに引っ越しました。ロサンゼルス近郊のニューポートビーチです。でも、結局来てすぐわかったのですが、その会社はリストラ中で、いちばん肝心な就労ビザのサポートもどうなるかわからず、非常に不安でした。

**トニー** なるほど、自分の力でいろいろと調べたりして来られたわけですね、ロサンゼルス方面からシリコンバレーには?

羽田 同じくロサンゼルス近郊のパサデナとかリバーサイドでも仕事を少しした後に小さな会社に入り、会社ごとシリコンバレーに移ったのです。引っ越してみたところ気候が全然違い、ロス方面と比べてかなり寒いので驚いた記憶があります。

シリコンバレーに来て6年半になりますが、最初は知り合いがまったくなく、インターネットでいろいろと友達を増やしていきました。仕事は newsgroup の仕事カテゴリと Web で検索し、ヒットした250件ぐらいの募集に何も読まずに自分のレジュメを送りました。友達のほとんどはメーリングリストで知り合いました。Adobe の仕事は、趣味のバイクやゲームのメーリングリストで知り合った人からの紹介でした。

トニー う~ん、なるほど……インターネットで徹底的にネットワークを広げているようですね。やっぱり自分をサポートしてくれたり知らないことを教えてくれる人をうまく周りに見つ

けるのは大事ですね.

#### ☆ Adobe での仕事について

トニー 小さい会社から Adobe に入ってどうですか? Adobe は、現在シリコンバレーを代表する会社になっていますよね、たしか全米でも HP などと並んで福利厚生がしっかりしているので「働きやすい会社」にランクインしていると覚えています.

**羽田** そうですね、落ち着いた感じがあります。入る前の会社が社長と二人だけだったりと、不安定な感じだったこともあるかもしれませんが。また、グループが一致団結して仕事をしていると感じられ、非常に仕事はやりやすいです。わからないことなどは、バグデータベースや社内メールでやり取りをしたりしますし、オフィス<sup>注1</sup>へ聞きに行くことも多いです。

▶=─ 現在のお仕事では具体的にどんなことを?

羽田 Adobe では、1年ほど QE (Quality Engineer、品質エンジニア)をしていまして、その後、おもに Web 関連のサーバスクリプトの開発を行うグループに移りました。C++や Java も少し使ったのですが、VBScript、Jscript、PHP、JSP などのスクリプト言語が多かったですね。また、Adobe の製品を拡張するために JavaScript ベースの言語をよく使いました。でも、型宣言の甘い言語はデバッグがとてもたいへんなので好きになれませんね (苦笑).

現在は、違うチームで Whitebox QEの仕事……プログラムも書く QE をやっています。ここでは JavaScript、VB、AppleScript を使っています。また、テストファイルを作成するために PHP を利用することがあります。ツール系では、Perforce、Visual Studio、秀丸、FileMaker Pro をよく使っています。

トニー なるほど、やはり最近はスクリプトを使う傾向が多いのですね、そのほかに今後どんな分野に興味がありますか?

羽田 Web のサーバサイドのプログラミングに興味があります。WDSLベースのオーサリングなどですね。サーバサイドの分野としては大きくなりましたが、やはり自分の作ったプログラムをいろいろな人に見せられる満足感が得られるのかもしれません。今後アメリカではブレイクするワイヤレスのクライアント・サーバ系も面白いと思っています。

#### ☆ 起業と本当にやりたいこと

**トニー** それでは今後またスタートアップとかに行くとか?

羽田 そうですね、スタートアップに1人の従業員として入ることにはもう魅力を感じられません。自分ががんばっても会社の都合でリストラなどがありますから、また、ストックオプ

注1: Adobe はサンノゼ市のダウンタウンに位置し、シリコンバレーでは 珍しい高層ビルに入っている。オフィスは、1人1部屋の個室がほと んどである。

### 対談編

ションや給与面でも起業するほうが割が合うと思うのです。従 業員だとやはり従業員の給与ですから。だから、ぜひ起業して 経営する側にまわってみたいと思っています。

▶=→ なるほど、たしかにシリコンバレーでは大きく二つに 分かれると思いますね、スタートアップが好きな人と大手企業 でしっかり仕事をしたい人と……あまりまん中がないですね。

羽田 じつは私にはもう一つ課題があります。実家は製茶業をしています。30歳になるまでコンピュータの仕事をして、その後は実家の仕事を継ぐ約束を父親としていました。今は31歳なので父親との約束を破ってしまっています。それでなんとかしたいと考えていました。

お茶の業界も変化があるわけで、海外でお茶をやっている大きなメーカーもあるし、家族経営的にやっているところは縮小しています。自分は、これまではハイテク業界でそこそこやってこれましたが、それもサラリーマンだし、家業経営とまた違うわけです。そして2001年の夏に読んだ本で『金持ち父さん、貧乏父さん』があり、この本にかなり感化されました。結論としては、自分には、財務的知識(Financial Literacy)が足りないと感じました。それで自分で株式投資、不動産などをいろいると試してみました。まあ、おかげで企業のバランスシートなども読めるようになりました。

▶=─ 財務知識は起業にはたいせつですよね。まあ、エンジニアだと、それほど難しくなくピックアップできますよね。

図田 しかし実際は、家業を手伝えるとか家業を大きくするための自信にはなかなかつながりませんでした。なにか空回りしていると感じ、自分にはさらに経営スキルが必要だと考えました。それで現在は会社に勤めながらサイドビジネスをやっています。これは、ハイテクとは関係のない仕事なのですが、これを少しずつやりながら経営スキルを身に付けようと思っています。もちろん技術的なスペシャリストになって、それをベースにして起業というルートもあるのですが、自分の空き時間でできることとか、他のバランスを考えて現在のサイドビジネスが自分にはもっとも適していると感じています。

▶=── 感覚は理解できますね. なにか自分でやりたいけれどどこからスタートしてよいかわからない....... 技術専門でいくか,経営でいくか? 私の場合はスタートアップにいきなりエンジニアから経営のほうに入りました. 起業家で声をかけてくれた人がいたのですが,私から1人の従業員のエンジニアとして入るのでなく,経営サイドに入りたいと提案したのです. それで入ったのですが,とにかくわからないことばかりでした.幸いパートナーがいて,二人で簿記の付け方からビジネスプランの書き方とか経営に必要な知識の研究と勉強をしました.全部見よう見まねでやったという感じでした.その日の午前中に

勉強したことを午後には平気で10年ぐらいやっているような顔をして投資家達に説明をしたりしてね……(皆笑). 冷や汗モノもあったのですがすごく身につきました. 1人で研究・勉強しなければならないこともたくさんあるのですが、幸い周りにお手本や教えてくれる人もいたので、いろいろ



羽田直樹氏

人にサポートをしてもらったと思います。起業の知識・ノウハウはスタートアップには濃くありますから、給料をもらいながらビジネススクールに行った感じですね。

羽田 スタートアップはシニアな人しか雇わないというイメージがあったのですが、いろいろなやり方があるのですね……なかなか面白い話です。現在のAdobeでの仕事はとても気に入っているので、それをやりながら何とかビジネススキルを磨いていきたいと思っています。ネットワークを広げたりして仲間を増やすこともたいせつですし。最終的な目標は、ハイテク企業を立ち上げて上場させてみたいですね。それでジェット機2台ぐらい所有できる一流企業に育てたいですね(笑)。あとは、趣味でやっているオフロードバイクがあるのですが、シリコンバレーのすぐ南にあるHollisterに、バイクに乗るパークがあります。1日4ドル出せば乗れるのですが、一回りするのに1時間強ぐらいかかる規模なので、日本では考えられないほど充実しています。こういうみんなが気軽にオフロードバイクを楽しめるパークを世界中に作りたいと思っています。

#### 対談を終えて:

**羽田** この対談は、自分の来た道を振り返る機会を与えてくれた、プログラミングは大好きだが、将来の自分の姿は別のところにあると感じる。自分の空き時間にそれに挑戦できる環境があるのはやっぱり幸せだ。昔は大好きだった TV ゲームも最近遊ばなくなった。これは、ルールがわかってくると、現実はTV ゲーム以上に面白いからか。

トニー 羽田氏は、本業のソフトウェアエンジニアリング以外にじつに多くの活動をされている。家業と自分の起業のためにやっているサイドビジネスや、英語のスピーチ向上のためにToastmasters <sup>注2</sup>など、かなり積極的かつ幅広い活動をされている。対談ではアメリカでの税法や小規模ビジネスの話など、筆者にとっては興味深い話が出たが、本誌の趣旨と離れているので残念ながら割愛した。今後の発展がじつに楽しみな若手エンジニアである。

トニー・チン htchin@attglobal.net WinHawk Consulting

注2:トーストマスターズクラブ:スピーチなど、人前で話す技術を向上 させるための非営利団体のグループ.

### HARD WARE

● 32 ビット RISC マイコン

### M32176 グループ

- 最大 512K バイトの大容量フラッシュメモリを 内蔵した 32 ビット RISC マイコン、書き込み 時間は512Kバイトで約7秒.
- •フラッシュメモリの書き換え温度範囲 は、-40~125℃の広域温度範囲に対応 したことで, マイコンの動作中や動作終了 直後の書き換えが可能
- 自動車用途の従来品「M32171 グループ」の 機能強化版で, ファンクションおよびピン 配置が互換であるため、従来システムの高 機能化, 高性能化が容易.
- 電源降圧回路の搭載により、3.3 または5.0V の単一電源動作とtyp.65mA(5V, 40MHz 動作時)の低消費電流化を実現。
- ・部品点数の削減が可能で、システムの低価 格化, 低消費電力化が図れる.

■(株)ルネサス テクノロジ サンプル価格: ¥5,000 TEL: 03-5201-5211



32 ビット RISC マイコン -

### MB91302

- SDRAM インターフェースをはじめ、SRAM、 非同期型 ROM (EEPROM, マスク ROM), フラッシュメモリ, FCRAM などのインタ ーフェースを搭載.
- 各種メモリとのダイレクト接続が可能とな り、データ処理速度の向上や部品点数削減に よるLSI設計の簡易化、低コスト化を図れる。
- データを CPU 部に取り込まずに、外部入 出力回路とメモリ間でダイレクトにデータ 転送を制御する専用回路, 高速 DMAC を搭 載しているため、従来に比べ約2倍の転送 レートを実現
- プロセステクノロジは、CMOS 0.25 μ m.
- •動作電圧は, 3.0V~3.6V(標準で3.3V).
- 各 4K バイトの ROM, RAM, キャッシュメ モリを搭載
- 最大動作周波数は, 68MHz.
- 外部供給クロックは 17MHz, PLL は 4 逓倍.
- おもな機能として、DMAC、ICU、PPG、 タイマ、リロードタイマなどを搭載
- パッケージは、QFP 144 ピンで供給.

■ 富士通(株)

価格: ¥1,200 TEL: 042-532-1397 E-mail: edevice@fujitsu.com ●統合コミュニケーションプロセッサ ――

### RC32365 Interprise アクセス・プロセッサ

- 最大 150MHz で動作する 32 ビット MIPS CPU コアの CPU
- SDRAM メモリコントローラ,業界標準 MII インターフェースをもつ2系統の Ethernet MAC を内蔵し、広範囲なネットワーキング デバイスや装置と接続することが可能.
- バージョン 2.2 の 32 ビット PCI コントロー ラとバージョン 2.1 の 16 ビット PCMCIA インターフェースを内蔵
- PCI と PCMCIA インターフェースは、WLAN ソリューションを含む広範囲なペリフェラル とチップセットへのシームレスな接続を提供
- VxWorks や Linux などの一般的な組み込み 向け OS と互換性を保持.

■ 日本 IDT (株)

サンプル価格: \$17.00(10,000 個時) TEL: 03-3221-6726 FAX: 03-3221-5456



●無線 LAN 用チップセット ――

### MN103S640L-H

- ・映像伝送標準形式の MPEG-TS 信号に対応 した入出力ポートを三つ備え、映像信号を3 ストリームまで直接入出力することが可能.
- 無線映像伝送する際のエラー発生、データ再 生により生じる時間的なずれをもとの画像信 号に合わせて高精度補正する機能を内蔵.
- IEEE802.11a 規格にしたがって、無線パケ ットごとに信号レベルを高速に検出し、ア ンテナを自動的に切り替える高速ダイバー シティ機能を搭載
- ・電波変動時の誤り率を従来比で1/10に低減
- 高周波プロセスである 0.25 µm SiGe Bi-CMOSプロセスをRF ICに採用し、低消費電 流で低歪, 低雑音の5GHz 高周波部ICを実現.

■ 松下電器産業(株) サンプル価格: ¥10,000 TEL: 075-951-8151

E-mail: semicon-press@mrg.csdd.mei.co.jp



● FPGA

### Spartan-3

- •5万ゲートから500万ゲートにおよぶ高集 積度を実現.
- ・組み込みブロック RAM および分散型 RAM の双方を組み合わせることが可能.
- 小さいチップ上に最大限の I/O パッドを搭 載するために、2重リングのスタッガーパ ッド配置を構成
- 最高 3300 億 MAC/秒という DSP アプリケ ーションに対して, 低コスト性を備えた組 み込み DSP 機能を提供
- 最高 104 個の組み込まれた 18 ビット乗算 器と分散型 RAM エレメントを装備。
- PCI 32 ビット/33MHz および PCI 64 ビット /33MHz を含む 23 種のパラレル I/O スタン ダード、シングルエンドとディファレンシ ャルシグナルの両方の信号形式に加え、他 の通信およびネットワーキングのアプリケ ーション用として一般的なパラレルコネク ティビティコアをサポート.

■ ザイリンクス(株) 価格:下記へ問い合わせ

TEL: 03-5321-7740 FAX: 03-5321-7762

● TFT 液晶パネル ―

### HTPS D4 シリーズ

- 液晶プロジェクタ向け高温ポリシリコン TFT 液晶パネル.
- 高精細加工技術により 12 μm 画素ピッチを 実現. 同一サイズでの開口率を向上.
- 同一画素ピッチでも従来と同レベルの開口率を 実現することで、液晶サイズの小型化を実現、
- •新平坦化技術,新液晶(2.5 μm)を採用する ことで、なめらかな映像を実現.
- ・従来と比較して、応答速度を 25%改善。
- 高効率化により同一ランプでの輝度を向上.
- 同一解像度、同レベル開口率での液晶サイ ズの小型化およびハイコストパフォーマン スを実現.

■ セイコーエプソン(株)

価格: 下記へ問い合わせ TEL: 042-587-7665

URL: http://www.epsondevice.com/



### HARD WARF

●モータドライバIC ----

### LB1935T

- 低飽和駆動、低電圧動作、正/逆モータドラ イバを2チャネル搭載した、カメラ付き携 帯電話などに用いられる2相ステッピング モータの駆動用IC
- CPU からの信号によりモータを直接制御す ることができ、3本の信号線による2相ステ ッピングモータの2相励磁駆動用に適する.
- 出力は上側 PNP + 、下側 NPN のバイポー ラタイプで構成されており、小型パッケー ジながら低飽和駆動, 低電圧動作を実現.
- サーマルシャットダウン回路(過熱保護回
- MSOP10 (3.0 × 4.9mm) の小型パッケージ のため、基板実装の省スペース(面積比 50%減。体積比 70%減) を実現。

■ 三洋電機(株) サンプル価格: ¥100

TEL: 0276-61-8107 FAX: 0276-61-8730



■フラッシュメモリー

### MBM29BS12DH MBM29SL800TE MBM29SL800BE

- 「MBM29BS12DH | は 1.8V の低電圧電源で 動作する、携帯機器向け NOR 型 128M ビ ットのフラッシュメモリ、「MBM29SL800TE」 「MBM29SL800BE」は Bluetooth などの無線 通信モジュールや超小型携帯機器向けスー パー CSP を採用した NOR 型 8M ビットの フラッシュメモリ.
- 「MBM29BS12DH 」は、電源投入後のアドレ ス固定からデータの出力までのイニシャル タイムは、最速で 46ns、バーストモード時 のアクセスタイムは 8.5ns で, コンフィグ レーションレジスタの設定により、システ ムに最適なバーストモードの選択が可能。 バーストアクセス読み出しを実現するため に、2ワード分のセンスアンプ数におさえ ることで,消費電力を低減化.
- 「MBM29SL800TE」「MBM29SL800BE」は、 省スペース化が可能で,チップ単体に比べ 二次実装信頼性が向上、動作電圧 1.8V で、 アクセスタイム 90ns の高速動作を実現

■ 富士通(株)

価格: MBM29BS12DH ¥4,000

MBM29SL800TE/MBM29SL800BE ¥400

TEL: 042-532-1416

E-mail: edevice@fujitsu.com

●マイクロパワー昇圧コンバータ -

### LT3464

- ショットキダイオードと短絡保護付き出力 切断 PNP トランジスタを搭載。
- ・85mAスイッチを内蔵し、電流制限付きの 一定オフタイムスイッチング方式を採用す ることで、最大 34V の電圧を供給.
- 3.6V 入力から 16V/8mA を供給可能なので、 ハンドヘルド機器のバイアスアプリケーシ ョンに適する
- 2.3 ~ 10V の入力電圧範囲により、1セルまた は2セルのリチウムイオンバッテリやマルチセ ルのアルカリまたは NiMH バッテリに適する.
- バーストモード動作により、25µAの超低 消費電流が可能で、シャットダウン時には 0.5 u A 以下に低減される.

■ リニアテクノロジー(株) サンプル価格: ¥180~(1,000 個時)

TEL: 03-5226-7291 FAX: 03-5226-0268 URL: http://www.linear-tech.co.jp/



●クロックシンセサイザー

### CDC7005

- VCXO (電圧制御水晶発振器) の位相を, リ ファレンスクロックに同期する機能を装備。
- 低雑音の位相周波数ディテクタ,精密チャ ージポンプ, プログラマブルデバイダ, OP アンプ, 分周オプション付きの1:5 差動クロックバッファなどを集積.
- 低い位相雑音特性を備え, A-D コンバータ, D-A コンバータ、シリアライザ、ASIC、 DSP などのリファレンスクロックへの精密 な同期が必要なシグナルチューンデバイス に利点を提供.
- リファレンスクロックとして、3.5MHz~180 MHzの範囲の入力と、それに同期させるた めの 10MHz~800MHz の VCXO が必要.
- 低スキューの差動出力を5個提供し、 10MHz以下の帯域でも最適な PLL のルー プ帯域幅の選択が可能、また、リファレン スクロック入力信号に含まれるジッタを除 去する機能を装備.
- 内蔵の OP アンプは、ループ帯域幅を最適 化するためのアクティブフィルタとして使 用可能

■ 日本テキサス・インスツルメンツ(株)

価格: \$13.8(1,000 個時) FAX: 0120-81-0036

● ATX シャーシ/セットアップ PC ー

### MPC シリーズ

- すべての外部ケーブル配線をフロント側に 集中することで、すばやいメンテナンスが 可能な組み込み向け PC.
- 背面にメンテナンスハッチが不要なため. 収容される端末,装置全体を低コストでコ ンパクトに設計可能.
- •メインユニット引き出し、トップカバー跳 ね上げ機構のメンテナンス重視の設計のた め、端末装置に設置したままメンテナンス が可能
- ・市販のATX仕様のマザーボードの組み込み が可能
- 拡張ボードクランプ機構を標準装備。

■(株)コンテック 価格:オープン価格

TEL: 03-5628-9286 FAX: 03-5628-9344

E-mail: tsc@contec.co.jp



● IC カードリーダ/ライタ —

### RR-01-01/RR-01-02 /RR-01-03

- RR-01-01 は標準無線 LAN, RR-01-02 はエ アロネット仕様無線 LAN、RR-01-03 は Ethernet にそれぞれ対応
- ISO/IEC15693 の国際標準に準拠した, 非接 触 ICカードリーダ/ライタで、市販の IC カー ドやタグを利用したシステムの構築が可能.
- ・無線 LAN 環境が構築されたエリア内であれ ば、自由に設置場所を移動することが可能.
- 無線 LAN のセキュリティが強化されたエア ロネット仕様のモデルのほか、標準仕様の 無線 LAN モデル、有線 LAN 仕様のモデル をラインナップ.
- 添付のユーティリティソフトにより、ユーザ ID やパスワードなどの初期情報の書き込み、デ ータのロックなどを画面上で行うことが可能。

■ 日本電気エンジニアリング(株)

価格: オープン価格 TEL: 042-333-4673



PRODUCTS | NEW PRODUCTS | NEW PRODUCTS | NEW PRODUCTS | NEW PRODUCT.

### HARD WARE

●レンズユニット・

### FMZ10

- FDK (株) と共同開発の,携帯電話や PDA などに搭載する小型カメラ向けのレンズユニット.
- ・光学 2 倍ズーム機能とマクロ撮影機能を 搭載
- ・新開発の小型電磁アクチュエータを利用し、 3群3枚で構成される非球面レンズの後群 レンズのみをユニット内部でスライドさせ ることにより、レンズ部がせり出すことな くズームやマクロ撮影を可能にしている。
- 容積は 1.1cc を実現
- 樹脂レンズの採用と機構部の簡素化により 落下などの衝撃に強い構造を実現。
- イメージセンサは、1/7 インチ CCD および 1/7 インチ CMOS の両方に対応が可能。
- 駆動電圧は 3V, 駆動電力は 0.45W.
- F値は 2.8 ~ 3.9, 撮影距離は 3cm ~∞.

■ (株) マクニカ 価格: 下記へ問い合わせ TEL: 045-470-9851

●フラッシュメモリ用 IC ソケットー

### **TSOP**

- サンテスト社が開発したアミューズメント 業界向け、TSOP56 ピンフラッシュメモリ 用IC ソケット。
- ・ホルダ上面に大開口部を設け、シールを 貼ったデバイスを目視で確認可能。
- ワンタッチロック方式により、操作性に優れている。
- 鉛フリー対応で、耐熱樹脂を採用。
- IC をふたにホールドすることで, 足曲がり を防止.
- 実装機対応のためのエンボステーピング 梱包。
- はんだ付け端子の肉眼による確認が可能.
- ソケットの挿抜を 30 回まで可能にし、リサイクルにも対応。
- ふたは2種類提供され、48/56 ピンパッケージの装着が可能。
- ICの抜き取り治具を用意。

■ 加賀テック(株) サンプル価格: ¥350

TEL: 03-5207-5661 FAX: 03-5207-5664

●メタチャネルモジュール ―

### APM-750

- 複数のシステム間でメモリを共有させることができる、ギガチャネルモジュール。
- 接続ケーブルには RJ-45 のメタルケーブル を使用し、通信速度は 3.2Gbps の高速を 実現
- 各ノードに搭載するモジュールのメモリをメタルケーブルでループ状に接続し、この間を通信データを載せたフレームを順次転送することで、高速データ転送を可能にする。
- 独自仕様のシンプルなプロトコルを採用しているため、異なる OS (VxWorks, Linux, Windows 2000/XP) やシステム間でもデータの共有が行える。
- 最大で 128 台の製品を接続することが可能 で、CompactPCI モジュールなど、組み込 みモジュールコンピュータの拡張用の PMC タイプとなる。
- 通信機能をハードウェアで実現し、任意の ノード間への割り込みにも対応.

■ (株) アバールデータ 価格: ¥198,000

TEL: 042-732-1030 FAX: 042-732-1032

● ICE ツール —

### advicePOCKET

- 低価格市場をターゲットにし、OCDツール に特化したICE製品でJTAG対応ツールと フルICEシステムをリリース。
- ・対応 CPU は ARM.
- JTAG インターフェースによる, 簡単接続 を実現,
- 1.8V ~ 3.3V の幅広い電源電圧に自動追従.
- 最高 200MHz までの分岐 PC トレースに対応
- サンプルのトレース&タイムスタンプは、 256Kという大容量をサポート。
- 外部フラッシュメモリへの書き込みに対応.
- 外部トリガ入出力機能による,連携デバッグに対応。
- ホストへの接続は、USB対応。

■ 横河ディジタルコンピュータ(株) 価格:下記に問い合わせ

価格:下記に問い合わせ TEL: 042-333-6222 FAX: 042-352-6107



● CPU ボード―

### ROCKY-512EV

- 台湾 ICP 社が開発した、ISA ハーフサイズ (185 × 122mm) でローパワー CPU を搭載 した CPU ボード。
- CPU とメモリがオンボードで搭載されているため、インストール、組み込みが容易.
- 低消費電力の NS GX1 300MHzCPU は、環境温度 60 °Cまでファンレスで動作が可能。
- オンボード SDRAM は、64M バイトおよび 128M バイトの2種類を用意。
- 拡張用に最大 512M バイトの DIMM ソケットを用意しているため、合計 640M バイトまでのメモリが搭載可能。
- ディスプレイは、CS5530Aチップセットを 内蔵

(株)ケーメックス価格:下記へ問い合わせ

TEL: 03-5295-3111 FAX: 03-5295-3123

E-mail: info@kmecs.co.jp URL: http://www.kmecs.com/



●プロトコル解析用測定器 -

### IEEE1394B データ アナライザ [IP1200]

- IEEE1394b-2002 に対応した, プロトコル 解析用測定器.
- IEEE1394a-2000 および IEEE1394b-2002 の双方に完全対応する, バイリンガル仕様
- Web プラットホームを採用し、汎用ブラウザ上で動作するため、HMI として使用するパソコン OS の種類を問わない。
- ネットワーク経由で遠隔地からの操作も可能.
- ディスプレイとキーボードを接続することで、スタンドアロン型のアナライザとしても利用可能
- データの物理層だけではなく、AVC、SBP-2、IPv4Over1394の3種類の上位プロトコルの解析機能を標準装備。

■ 横河電機(株)

価格: ¥2,900,000

TEL: 0422-52-5556 FAX: 0422-52-6624



### HARD WARE

●インバー夕用 DeviceNet 通信ユニット/カード

### 3G3MV-PDRT2 3G3RV-PDRT2

- インバータに搭載することで、インバータ や周辺機器を監視し、設備の故障診断や故 障予知に生かせる機能を搭載。異常が発生 してから復旧までのダウンタイムを短縮す ることが可能。
- ・定速運転中時、加減速中時のそれぞれの出 力電流値に閾値を設定し、出力電流が閾値 を超えると警告を発するワーニングトルク 機能を搭載
- 電力トレース機能は、モータの出力電流波形 を 150 個までサンプリングすることが可能.
- サンプリング周期に応じて、出力電流値を インバータ内部に記憶させることができる。

■ オムロン(株)

価格: 3G3MV-PDRT2 ¥39,000 3G3RV-PDRT2 ¥39,000

TEL: 055-977-9025



●箱型標準電源

### RTW シリーズ

- ・独自の熱設計シミュレーション/実装技術と 回路技術の最適化により高効率を達成した 小型電源
- 50W タイプと 100W タイプをリリース.
- 厚さ寸法 22mm (50W タイプ), 重さ 250g と, 従来品と比較してサイズを 50%小型化.
- 標準の1Uラックサイズ(44mm)にも余裕を持った実装ができ、電源の裏表両面からの取り付けが可能。
- ・省スペース化,省資源化を実現しつつ,各 国の安全規格,ノイズ規格,高周波電流規 制,CEマーク適応など各規格に対応.

■ TDK(株)

サンプル価格: ¥8,400 (50W シリーズ) ¥11,800 (100W シリーズ)

TEL: 03-5201-7102



● USB 開発キット-

### USB-004-DK

- FTDI 社の USB-FIFO 変換 LSI, USB-シリア ル変換 LSI を用いた開発キット。
- USB-004-FIFO と USB-004-SER のセット に,デバイスを各 1 個 (FT245BM と FT232BM)をセットにしたキット.
- USB-004-FIFO は、FT245BM を使用した USB-FIFO 変換基板、8 ビットパラレルポートと、四つの制御信号で FPGA/CPLD 基板、マイコンとの接続が可能、仮想 COM ポート (VCP) ドライバを用いて、アプリケーションから COM ポートとして操作が可能
- Windows 98/Me/2000/XP に対応したドライバのほか、Linux や Mac 用のドライバも用意。

■(有) ヒューマンデータ 価格:下記へ問い合わせ

TEL: 072-620-2002 FAX: 072-620-2003



● USB2.0 リンクケーブル -

### 瞬転 U2LC-480

- パソコン間を USB で直結し、ファイル、 データの転送が可能。
- USB2.0 のハイスピード (480Mbps) 対応で 高速転送が可能
- ASIC をケーブルの中に組み込んだシンプルな構造で、ノートパソコンのデータ転送に適する
- 重さ 120g の軽量.
- プラグアンドプレイ対応で, 簡単接続を実現.
- USB 自身から電源を供給するタイプなので、電源が不要
- USB1.1 のホストでも使用可能.

●無線プリントサーバ -

### KP-612air

- プリンタに直接接続して簡単に無線ネットワーク化できる,1ポートマルチプロトコル無線プリントサーバ。
- 300K バイト/s のスループット性能を実現しており、プリンタの性能を最大限に引き出すことが可能。
- 有線,無線の混在環境でも速度を気にせず に印刷可能.
- データ形式をバイナリタイプにも対応する ことで、印刷データのサイズを小さくする ことができる。
- プリンタメーカ純正ドライバを使用した印刷も可能.

■(株)小松製作所

価格: ¥24,800 TEL: 045-441-2701

E-mail: lan\_sale@komatsu.co.jp



●ライトパルサ ―

### **PLP-10**

- LD を用いた超短パルス光源で, コントローラとレーザダイオードヘッドで構成.
- 400nm  $\sim 1550$ nm までの波長範囲で 8 種類 のレーザダイオードヘッドを用意.
- 最大 100MHz までの高繰り返しが可能で、 従来品と比較して出力光が強く明るくなり、光軸調整も簡単。
- POF 光通信やギガビット Ethernet 用のファイバ周波数特性評価,受光素子の応答特性評価などで,タイミング調整が簡単となり,信号をとらえるための周辺機器も不要.
- ・蛍光寿命測定用の励起光源として、データの取得時間が短くなり、より多彩な用途に使用することが可能。

■ 浜松ホトニクス(株)

価格: ¥1,240,000~

TEL: 053-452-2148 FAX: 053-452-2139

E-mail: sales1@sys.hpk.co.jp



### ■(株)コンパル

価格: ¥6,980

TEL: 03-3299-5751 FAX: 03-3299-5059

URL: http://www.compal.to/

PRODUCTS | NEW PRODUCTS | NEW PRODUCTS | NEW PRODUCTS | NEW PRODUCT

### SOFT WARE

●プロセッサ開発キット・

### Nios エンベデッド・プロセッサ 開発キット Cyclone エディション

- Nios エンベデッドプロセッサ Ver3.0, Cyclone EP1C20 デバイス, Quartus ■デザインソフトウェア, SOPC Builderシステムデザインツール, およびソフトウェア群が含まれる.
- ・Cyclone EP1C20 デバイスを搭載した Cyclone 開発ボード、1M バイトの SRAM、16M バイトの SDRAM、8M バイトのフラッシュ、10/100BaseEthernet ポート×1、シリアルポート×2、ソフトウェアデバッグ用 Mictor コネクタ×1、拡張ヘッダ×2、電源およびダウンロードケーブル×1で構成
- オンボードフラッシュメモリにプリロード されたリファレンスデザインとハードウェ アおよびソフトウェアチュートリアルが含 まれる。

■ 日本アルテラ(株)

価格: \$995

TEL: 03-3340-9415 FAX: 03-3340-9487

URL: http://www.altera.co.jp/

●プリント基板設計/製造の通販サービス ―

### P板.com

- 2 層、4 層のローエンドな基板に特化し、  $1 \sim 50$  枚までの小ロット製造を専門とする、インターネットを利用したプリント基板の設計と製造サービス.
- 受注可能な基板の仕様を標準化することにより、効率化された製造フローを提携先の 海外工場(韓国、台湾)と構築し、初期費用 の完全無料化を実現。
- 標準的な仕様での設計納期は最短で4日, 設計見積は受付完了から3時間以内に回答.
- 製造納期は最短で3日,製造見積は仕様入力時に即時自動回答.
- 標準仕様は、ピン数 200 ピン、外形サイズ 70×90mm、層数 2 層、枚数 5 枚、指定回 路図 CAD (D2CAD、PROTEL、ORCAD) データでの受注
- 品質と納期の管理は、各国で専属契約を結 んだ国際調達会社(IPO)が行う。
- ・品質保証として、出荷する全枚数に「オープンショート検査」を無料で実施。

■ (株) インフロー

価格: ¥43,000~

TEL: 03-5228-7871 FAX: 03-5228-7872

E-mail: info@p-ban.com URL: http://www.p-ban.com/ ●ネットワーク構成図作成用ユーティリティ ―

### **NetZoom**

- Visio, PowerPoint, AutoCAD, Illustrator などのソフトと同時に使い、プロフェッショナルなプロポーザルやプレゼンテーション用の資料作成が可能。
- NetZoomStencil, NetZoom, NetZoom Symbol の 3 種類があり, 技術者あるいは 用途により使い方が異なる。
- Cisco, IBM, SUN など 1,100 以上のメーカ と 50,000 点以上の機器のイラストを Visio, PowerPoint などのホストアプリケーション 内にドラッグアンドドロップ可能,
- 12 か月間イラストを更新ダウンロード可能 なスタンダード版と、30 日間用のベーシッ ク版を用意

■ アイ・ビー・エス・ジャパン(株)

価格: 下記へ問い合わせ TEL: 046-234-9200

E-mail: press@ibsjapan.co.jp

● Web 高速化ソフトウェアー

### FlyingServ Web キャッシュ

- ネットワーク回線への投資を抑えながら、 Web システムの応答性能を飛躍的に改善。
- Web コンテンツデータのハッシュ値を利用 した差分管理機能により,動的コンテンツ を効率よくキャッシュすることが可能.
- 静的コンテンツに対応する通常のキャッシュ機能,クライアントに流れるデータを圧縮して送る機能をサポートし、ネットワークを流れるデータの削減を実現
- ・Web コンテンツの一部だけが変更されるような定型業務に対しては、データを大幅に削減することが可能となるため、低速なネットワーク環境で稼動する Web システムでもコストの大きな回線投資をすることなく、少ない投資で Web システムの応答速度を上げることが可能
- Web サーバ側アプリケーションの変更はないため、既存の Web システム環境に導入が容易。
- 検証支援サービスなどのサポートサービス も提供。

■ (株)東芝

価格: ¥1,500,000 (サーバプロキシ/1CPU) ¥150,000 (クライアントプロキシ/1CPU)

TEL: 03-3457-2725

● Linux 製品開発ツールキット -

### RADVISION SIP 開発ツールキット /RADVISION H.323 開発ツールキット

- MontaVista Linux Professional Edition を使用した Linux ベースの製品の開発向けツールキット。
- ・RADVISION SIP 開発ツールキット バージョン 2.2 は、オープンなオブジェクト指向型のアーキテクチャをもち、ハイレベルAPI からミドルおよびローレベルAPI まで複数の階層型 API をサポート、メッセージエンコーディング/デコーディング、トランザクションとコールマネージメントなどすべての SIP 固有の機能や、REFER、リプレース、PRACK、SUBSCRIBE NOTIFY など多くの SIP 拡張を含んだライブラリを装備、SDP、RTP/RTCP ライブラリも装備.
- ITU H.323 バージョン 4.0 をベースとした, RADVISION H.323 開発ツールキットは, 包括的な ITU 機能のセットと低消費メモリ で高性能を提供。移植性が高く, すべての ネイティブおよび組み込みプラットホーム に対応

■ モンタビスタソフトウェアジャパン(株)

価格: 下記へ問い合わせ TEL: 03-5469-8840

**●開発ソリューション** -

# CodeWarrior Development Studio for Symbian OS v2 OEM Edition

- JTAG ハードウェアを使用して Symbian OS Ver.7 のストップモードでのカーネルレベルデバッグを行える.
- UIQ と Series60 をベースとする携帯電話用 Symbian アプリケーション開発のための総 合的なツール群も提供し、ROM に常駐す る Symbian のアプリケーションフレームワ ークコードのデバッグが可能.
- MetroTRKも含まれており、リファレンス プラットホームと Symbian 開発キットにより、ターゲットデバイス上で JTAG 接続な しでシリアルケーブルを使ったデバッグを 行うことが可能。
- グラフィカルなデバッガは、GNU デバッグ ツールと比較してさまざまな機能向上がな されている。

■ メトロワークス (株) 価格:下記へ問い合わせ

TEL: 03-3780-6091 FAX: 03-3780-6092

### SOFT WARE

■ Linux カーネル/統合クロス開発環境 —

### uLinux/ELITE

- uLinux は同社が提供する Linux カーネルで あり、ELITE は、製品に Linux ベースの組 込みソリューションをコンフィグレート, カスタマイズ、デプロイするための組み込 み Linux 開発環境.
- ELITE は、Linux ホストでの開発環境だけ でなく、Windows ホストでも Linux と同等 の開発環境を提供
- コンポーネントをモジュール化し,再利用 や管理を促進するための Java ベースの IDE
- プロジェクト生成ウィザード, コンフィグレー ションツール、ビルドツール、ターゲットイ メージエディタ、デプロイウィザード、デバ ッグウィザードの六つのツールにより構成.
- •SH系, ARM系, MIPS系, PPC系および MMU のない CPU に対応.
- リアルタイム機能, オプションでサードパー ティのデバッガツールへの対応など、従来の 開発ツールとは異なる特徴をもち、サードパ ーティを含むオプションソフトウェアスタ ックをスナップイン対応する機能も装備.

■ リネオソリューションズ (株)

価格:下記へ問い合わせ

TEL: 03-5322-2856 FAX: 03-5322-2858

●機械設計支援ソフト -

NEW PRODUCTS

### AutoMECH 2004

- オートデスク社の AutoCAD 2004 に対応し た機械設計支援ソフト.
- AutoCAD 2004 に搭載された VeriSign によ る「ディジタル署名」と連動するハンコ機能 を搭載. 図面内にハンコ図形を挿入するこ とで、図面ファイルの認証を行い、許可な く改ざんされていないことを保証
- 部品表と表題欄の機能が一新され、入力さ れたデータは PDI を介して CSV/XML に出
- ・機械設計において多く利用される, 寸法線 機能を強化
- 初期設定,補助線, JIS 基本機械要素/地図 記号の自動記入, 異尺作図, 作表, コネク タなど機械設計に必須の機能を多数搭載。

■ (株)エス. アール. ディー 価格: ¥248,000

TEL: 06-6392-9511 FAX: 06-6392-9524



●レイアウト2次元最適化ツール

### Otrek

- 米国 **Q** デザイン社が開発した、ディープサ ブミクロンプロセスの半導体向けレイアウ ト2次元最適化ツール.
- 「Qtrek-Create」,「Qtrek-Migrate」の二つの 製品で構成され、GDS フォーマットを経由 したスタンドアロンで使用可能.
- SII の ULSI デザインシステム New-SX およ び SX-9000 と統合して動作.
- Qtrek-Create は, New-SX/SX-9000 の環境 内で、マスクレイアウトの最適化を行うこ とができ、New-SX/SX-9000 のメニューか ら直接起動することが可能. データベース を統合しているため、マスクレイアウトの 2次元最適化の実行結果を New-SX/SX-9000 で直接確認することができる.

■ セイコーインスツルメンツ(株)

価格: ¥6,500,000~ TEL: 03-5645-1741



●.NET 用難読化ツール――

### **Dotfuscator**

- 米国プリエンプティブソリューションズ社が開 発した、 NET 開発環境向けの難読化ツール、
- ・短い名前に置き換えるだけでなく、拡張され たオーバロードインダクション機能により, メソッドの戻り値の型を判定し、短い名前を 重複利用するため、逆コンパイルによるソー スの復元を最大限に困難にする.
- 文字列の暗号化を行う.
- コントロールフローに対して難読化が可能
- サテライト DLL のシームレスな難読化が可能。
- 印字不能文字を対象とするリネームが可能.
- 不要なタイプ, メソッド, フィールドの除 去や不要なコンスタントやインスタンス変 数の除去も行い、最大70%までのサイズ縮 小を実現
- プログラムサイズの縮小にともないローデ ィングに要する時間が短縮され、起動速度 が向上
- ILDASM 対策機能や、XML ベースの使いや すい設定ファイルを用意.

■ (株)エージーテック

価格: ¥290,000

TEL: 03-3293-5283 FAX: 03-3293-5270

E-mail: info@agtech.co.jp URL: http://www.agtech.co.jp/ ●統合設計環境ツール ―

### **Qsim System**

- ディジタル通信システムや信号処理向け に、アルゴリズム設計から RTL 設計までを シームレスに設計する環境を提供する機能 を多数搭載している.
- 単相同期方式とゼロ遅延モデルのシミュレ ーションに適したサイクルベース方式を採 用したシミュレータにより、イベントドリ ブン方式と比較して高速なシミュレーショ ンを実現
- シミュレーション結果をロジック波形オシ ロスコープなどにより動作を確認でき、モ デル中の任意の信号線をプローブを当てる ような感覚で波形を見ることができる。
- ツールは動的にシミュレータに組み込むこ とが可能なプラグイン方式を採用してお り、公開されている API を利用して必要な 表示ツールを構築することも可能.
- MATLAB/Simulink で記述したモデルを IP generator ツールにより自動的に RTL モデ ルに変換し、シミュレーションすることが

■ (株)キューウエーブ 価格:下記へ問い合わせ

TEL: 03-3485-2900 FAX: 03-3485-2900

●ディジタル文書作成ツール ―

### Acrobat 6.0 Professional Acrobat 6.0 Standard

- Acrobat 6.0 Standard は、ビジネスユーザー 向けに PDFファイルの作成、レビュー、文書の やり取りのための使いやすいツールを提供
- Microsoft Office O Word, Excel, Power Point, Outlook からボタン一つで PDF を作 成. Windows 版 IE にもボタンを埋め込み、 すべてのリンクを保持した状態で, ブラウ ザ内から自動的に Web ページを保存.
- レビュートラッカーによって、レビューメ ンバのリストを自動的に作成し、送付した 文書や注釈に対するコメントが返信された かのトラッキングが可能. レビューは電子 メールまたは Web ブラウザを介して行う ことができる。
- Acrobat 6.0 Professional は、Standard 版の すべての機能に加えて、AutoCAD, Visio, Project などの専門分野のアプリケーション からの PDF 作成をサポート.
- AutoCAD と Visio で作成された PDF では、 レイヤ情報も保持. 拡張された PDF/X 準拠 と PostScript レベルの互換性の検証が可能.

■ アドビシステムズ(株)

価格: ¥54,800 (Professional) ¥34,800 (Standard)

TEL: 03-5350-0407

### NFORMATION

|         | 海外イベント                                                                                                             | ヤミナー棒部                                                                                                                                                                                                      |  |  |  |
|---------|--------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 5/25-28 | International Symposium on Cirsuits and Systems<br>Imperial Queen & Park Hotel, Bangkok, Thailand                  | <b>セミナー 情報</b> WindowsCE プリントシステムセミナー<br>開催日時 : 5月 27 日 (火)                                                                                                                                                 |  |  |  |
|         | <pre>IEEE http://www.iscas2003.org/</pre>                                                                          | 開催場所 : みなどみらい 2-3-3 クイーンズタワー B 7F クイーンズフォーラム会議室 (横浜市西区) 受講料 : 無料                                                                                                                                            |  |  |  |
| 6/2-6   | COMPUTEX TAIPEI Taipei World Trade Center, Taipei, Taiwan CETRA                                                    | 問い合わせ先:(株)グレープシステム基本ソフトウェア事業部セミナー係,<br><b>元</b> (045)222·3761, FAX(045)222·3759<br>http://www.grape.co.jp/seminar.html                                                                                      |  |  |  |
|         | http://www.taipeitradeshows.com.tw/computex/                                                                       | パソコン・リアルタイム OS プログラミング技法<br> 開催日時 : 5月 27日 (火) ~ 29日 (木)<br> 開催場所 : 高度ポリテクセンター (千葉県千葉市)<br> 受講料 : 35,000 円                                                                                                  |  |  |  |
| 6/3-5   | Infosecurity Canada Sheron Centre Hotel, Toronto, Ontario, Canada Reed Exhibitions http://reedexpo.ca/infosec/     | 問い合わせ先:雇用・能力開発機構 高度ポリテクセンター事業課,                                                                                                                                                                             |  |  |  |
| 6/9-11  | NEPCON East/Electro Bayside Expo & Conference Center, Boston, MA, USA Reed Exhibition http://www.nepconeast.com/   | 受講料 : 19,000円<br>問い合わせ先: サイペック(株), info@r-sipec.jp<br>http://www.rlz.co.jp/seminar/seminardata.php?id=RGS305802<br>UWB(Ultra Wide Band)の基盤技術と規格動向<br>開催日時 : 6月11日(水) ~ 12日(木)<br>開催場所 : 中央大学駿河台記念館(東京都千代田区) |  |  |  |
| 6/17-19 | International Conference on Consumer Electronics Lax Marriott Hotel, Los Angels, CA, USA IEEE http://www.icce.org/ | 受講科 : 68,500 円 (1 口で 1 社 3 名まで受講可)<br>問い合わせ先: (株)トリケップス, ☎(03)3294-2547, FAX(03)3293-5831<br>http://www.catnet.ne.jp/triceps/sem/c030611a.htm<br>Linuxデバイスドライバプログラミング<br>開催日時 : 6月11日(水)~13日(金)             |  |  |  |
| 7/14-16 | SEMICON West 2003<br>Moscone Center, San Francisco, CA, USA<br>SEMI                                                | 開催場所 : 高度ポリテクセンター(千葉県千葉市)<br>受講料 : 30,000 円<br>問い合わせ先: 〒 10,000 円<br>西(043) 296-2582<br>UMLによる組み込みシステムモデリング入門(演習つき)                                                                                         |  |  |  |
| 7/30-31 | http://events.semi.org/semiconwest/  Embedded Systems Conference Asia                                              | 開催日時 : 6月 12 日 (木)<br>開催場所 : CQ 出版セミナールーム<br>受講料 : 18,000 円                                                                                                                                                 |  |  |  |
| 1,30 31 | Taipei International Convention Center, Taipei, Taiwan CMP Media Inc. http://esconline.com/asia/                   | 問い合わせ先:エレクトロニクス・セミナー事務局,<br>☎(03) 5395:2125, FAX (03) 5395:1255<br>PC 実習!! TCP/IP ネットワーク・プログラミング<br>開催日時 : 6月12日(木)~13日(金)                                                                                  |  |  |  |
|         |                                                                                                                    | 開催場所 : SRC セミナールーム (東京都高田馬場)<br>受講料 : 78,000 円<br>問い合わせ先: (株) ソフト・リサーチ・センター, ☎(03) 5272-6071                                                                                                                |  |  |  |
| 5/26-30 | 国内イベント<br>INFORMATION STORAGE WEEK 2003                                                                            | http://www.src-j.com/seminar_no/23/23_143.htm<br>C言語ベースのシステム LSI 設計                                                                                                                                         |  |  |  |
|         | 東京ファッションタウン(TFT)ビル(東京都江東区)<br>国際ディスクドライブ協会 IDEMA Japan<br>http://www.idema.gr.jp/isw2003.htm                       | 開催日時 : 6月13日(金)<br>開催場所 : CQ出版セミナールーム<br>受講料 : 13,000円<br>問い合わせ先:エレクトロニクス・セミナー事務局,                                                                                                                          |  |  |  |
| 6/3-6   | RSA Conference 2003<br>東京国際フォーラム(東京都千代田区)<br>Key3Media<br>http://www.key3media.co.jp/rsa2003/                      | <b>☆</b> (03) 5395-2125, FAX (03) 5395-1255<br>組み込み用ボードを使った Linux システム設計入門<br>開催日時 : 6月 16日 (月)<br>開催場所 : アドバンスト・テクノロジーセンター (東京都千代田区)<br>受講料 : 73,500 円<br>問い合わせ先: (株) アドバンスト・テクノロジーセンター,                   |  |  |  |
| 6/4-6   | JPCA Show 2003 (国際電子回路工業展)<br>東京国際展示場(東京ビッグサイト, 東京都江東区)<br>(社)日本プリント回路工業会<br>http://www.jpca.jp/2003/index.html    | <b>☎</b> (03) 3518-6441, FAX(03) 3518-6147<br>http://www.at-center.co.jp/pdf/A_1279.pdf<br>リアルタイム OS の基礎<br>開催日時 : 6月 19 日 (木)<br>開催場所 : CQ 出版セミナールーム                                                       |  |  |  |
| 6/4-6   | ビジネスショウ OSAKA 2003<br>インテックス大阪(大阪府)<br>(社)日本経営協会<br>http://www.noma.or.jp/bsosaka/                                 | 受講料 : 13,000円<br>問い合わせ先:エレクトロニクス・セミナー事務局,                                                                                                                                                                   |  |  |  |
| 6/11-13 | <b>画像センシング展</b><br>パシフィコ横浜(神奈川県横浜市)<br>精機通信社<br>http://www.seiki-tsushin.com/sensing/                              | □ 15,000   1                                                                                                                                                                                                |  |  |  |
| 6/25-27 | 設計・製造ソリューション展<br>東京国際展示場 (東京ビッグサイト,東京都江東区)<br>リードエグジビションジャパン                                                       | 受講料 : 68,500円(1口で1社3名まで受講可)<br>問い合わせ先: (株)トリケップス, 〒(03)3294-2547, FAX(03)3293-5831<br>http://www.catnet.ne.jp/triceps/sem/c030626a1.htm<br>Windows Server 2003におけるシステムへの展開・運用・管理<br>開催日時 : 6月26日(木)~27日(金)  |  |  |  |
| 7/9-11  | http://web.reedexpo.co.jp/dms/ 組込みシステム開発技術展 ESEC                                                                   | 開催 場所 : SRC セミナールーム (東京都高田馬場)<br>受講料 : 76,000 円<br>問い合わせ先: (株) ソフト・リサーチ・センター, ☎(03) 5272-6071                                                                                                               |  |  |  |
|         | 東京国際展示場(東京ビッグサイト,東京都江東区)<br>リードエグジビションジャパン<br>http://web.reedexpo.co.jp/ESEC/jp/                                   | http://www.src-j.com/seminar_no/23/23_145.htm<br>XPort ソリューションセミナー<br>開催日時 : 6月 27日(金)                                                                                                                      |  |  |  |
|         |                                                                                                                    | 開催場所 : 日新電機東京支社<br>関催場所 : 日新電機東京支社<br>受講料 : 55,000 円<br>問い合わせ先: (株) 日新システムズ, ☎(03) 5807-5931, FAX(03) 3839-0112                                                                                             |  |  |  |
| 開催日,イイ  | 開催日、イベント名、開催地、問い合わせ先の順 http://www.co-nss.co.jp/index.html                                                          |                                                                                                                                                                                                             |  |  |  |

### アンケートの結果



- ①プロローグ 組み込み機器開発における問題 点と解決手法
- ②第1章 組み込みソフトの開発を考えたとき 不足していること
- ③第4章 組み込みソフト開発にオブジェクト 指向を導入した成果の測定手法
- ④第2章 エレベータモデルの検証
- ⑤第8章 開発効率化のための組織と Agile方 法論
- ⑥第5章 どうして組み込み分野でオブジェク ト指向が広まらないのか
- のフリーソフトウェア徹底活用講座(第9回)
- ⑧第6章 事業としての組み込み機器開発の課 題を整理する
- ⑨第3章 電波時計システムモデルの検証
- ⑩第9章 人的協働モデルとモデル作成者の 谪性
- ⑩第7章 ソフトウェアプロダクトラインとプ ロセスの定義
- ⑩音楽配信技術の最新動向(第4回)
- ® NET&COM 2003
- 毎開発技術者のためのアセンブラ入門 (第18回)
- ® InterGiga No.30
- ⑩組み込みプログラミングノウハウ入門 (第11回)
- ®Microwindows を使った組み込み向け GUI

プログラムの作成事例(基礎編)

- ⑩エピローグ 組み込み機器開発効率化のため の今後の取り組み
- ⑩ハッカーの常識的見聞録(第29回)
- ◎シニアエンジニアの技術草子 (弐拾七之段)
- ②プログラミングの要(第3回)

特集『うまくいく!組み込み機器 の開発手法』についての アンケートの結果

### 01 今回のように、現場エンジニアとコンサ ルタントといった、異なる立場からの解 説で構成される特集は?

- ①非常におもしろくたいへん興味がある(45%)
- ②仕事上でも十分に参考になる(27%)
- ③学習/評価用に役立つ(18%)
- ④話としてはおもしろい(g%)
- ⑤役に立たない(o%)
- ⑤その他(o%)

#### O2 今月号の特集はいかがでしたか?

- ①よく理解できた(36%)
- ②ある程度理解できた(63%)
- ③あまり理解できなかった(0%)
- ④ほとんど理解できなかった(o%)
- ⑤関係ない分野だった(0%)
- ⑥その他(0%)

### O3 今後、開発手法/オブジェクト指向関連 の記事に期待する内容/テーマ/トピック は?(複数回答可)

- ①オブジェクト指向プログラミング(5%)
- ②オブジェクト指向方法論(5%)
- ③ UML記法の解説 (5%)
- ④ UMLの適用事例(12%)
- ⑤プロジェクトメトリックス (3%)
- © Rational Unified Process (0%)
- ①オブジェクト指向分析(10%)
- ®オブジェクト指向設計(8%)
- ⑨デザインパターン(5%)
- ⑩組み込み向けオブジェクト指向(15%)
- ® eXtream Programming (8%)
- <sup>®</sup> Agile 方法論 (15%)
- ® CMM (3%)
- ゆプロダクトライン(5%)
- ®その他(0%)





### 特集担当デスクから

☆最近のPC/AT互換機では、最新Pentium4の800MHzFSBなど、 一昔前では考えられなかった周波数で動いています。今回の特集で、 そのからくりを理解していただけたかと思います.

☆バスは一般的に、性能を追求すれば互換性が問題になり、互換性を 重視すれば高性能化が難しくなります。規格化におけるそのバランス は、非常に重要な点です、USB2.0のハイスピードデバイスは、互換性 を確保しつつ大幅な性能向上を実現できたわけですが、その内部は互 換性のための回路を含むなど、複雑になっているのがわかります。



### 読者プレゼン

(1名)

に必要事項を記入のうえ、2003年6 月30日(必着)までにご応募ください。 なお当選者の発表は、発送をもってか えさせていただきます.

(1) IP SAN ーインターネット時代の ストレージ・ネットワーク技術』



# 次号予告

# 現代コンピュータ 技術の基礎

Linux/BSD/シミュレーション/データベース/ARM/文字コード処理/ コンピュータシステム/ワイヤレスネットワーク/IC カード/USB

最近のコンピュータ/エレクトロニクス技術は進歩がとても速く、新しい技術が次々 に開発されてくるうえに、細分化も進み、技術の動向を追うだけでもたいへんであ る、開発現場のエンジニアは、自分の専門以外の分野だと、内容をなかなか理解で きないこともある。そこで次号特集では、最近の本誌の特集記事(2002年7月号~ 2003年4月号)の中に出てきた、さまざまな用語について、詳細な技術解説を行う。 本誌特集は、その時点における重要技術を掘り下げて解説しており、その用語を理 解することは、ひいてはコンピュータ/エレクトロニクス技術の流れを理解する「早 道」ともなる.

また、別冊付録として、開発現場で役立つ「数式・公式集」が付属する。

### 編集後記

- ■新緑に浸って気分転換!とばかりに、自宅か ら10個ほど「奥」の駅へ家族で降り立ち、軽い山 登り&川遊びをしてきた. 開けた景色で飲む缶 Beer はとっても美味だった. 翌日, 痛みを訴え る足に,「やった,まだ若い!」と家人に「申告」 したら、「私は痛くない. その程度で痛くなると は足腰弱いねー|と「逆襲|されてしまった。(洋) ■とあるブラジリアン柔術の道場に次のような 張り紙がしてある。「タップは恥ずかしいことで はありません」、タップとは、関節を極められた 場合に、「まいった」の意思表示をすることであ る. 確かに、タップもせずに無理して我慢した ら,一生何もできない体になりかねない。「タッ プ」は決して恥ずかしいことではない. (= IO) ■ゴールデンウィークに編集作業の山場を迎え るうちの編集部にとって、今年はぜんぜん"ゴー ルデン"じゃなかったので作業も滞りなく進み... ...っというのは甘くて、筆者校正が大変、電話 番号から察するに、旅行先?にFAXを送るこ とになった筆者や、某筆者は巣鴨で缶詰に(!!) お休みのところ申し訳ありませんでした. (M) ■ノートPCのバッテリが死亡. まったく使えな くなったことから、最初は接触不良を疑ったの ですが、リチウムイオン電池は劣化すると、出 力が oV になるのだそうです. ニッカドだったら いくら劣化しても少しは使えるのですが...... 正しい知識を身に付けていれば、時間を浪費す ることもなかったのですが.
- ■バブルが崩壊してずいぶん経つが、イラク戦 争に伝染病と経済にとって悪いことが続く. 失 業率も上がっているしリストラ対象になってい る人も多いが, 不思議と日本経済が深刻な状況 になっているようには感じられない. 鈍感にな っているのだろうか、自分の感覚が少し心配だ. しかし、良い話もなさそうなので、もっと酷い 状況を覚悟しなければならないのかも. (Y)
- ■相方の友達が戸建を買ったので、御祝いに友 達数人でスロットの実機を贈ったそうです。夫 婦揃ってスロ好きで、欲しいと思ってもなかな か買えない物なので、たいへん喜ばれたとか、贈 り物する時ってけっこう悩むので喜ばれて幸い ですが、さすがにこれほどインパクトのある贈 り物ってそうそうないのでは(笑).
- ■今年に入ってから、山手線の外側を利用した 新たな路線の繋がりが頻繁に告知されており, 起点から目的地への最短の距離・時間・費用の 検索に情報提供各社が追いついていかないよう だ、特に、展示会場がある最寄り駅への行き方 は何通りも出来ており、利用する路線の選択・ 組み合わせを考えさせられる今日この頃.
- ■姉に赤ちゃんができたことがわかり、我が家 では連日その話題でもちきりらしい. 特に初孫 とあってか母が大騒ぎしている. 生まれる前で こうなのだから、生まれたらどうなることやら ...... 姉より母の方が心配である. 私も楽しみ にしている一人ではあるが.

### 2003年8月号は 6月25日発売です

### お知らせ

本誌に関するご意見・ご希望などを、綴じ込 みのハガキでお寄せください. 読者の広場への 掲載分には粗品を進呈いたします。なお、掲載 に際しては表現の一部を変更させていただくこ とがありますので、あらかじめご了承ください。

#### ▶投稿歓迎

本誌に投稿をご希望の方は、連絡先(自宅/勤 務先)を明記のうえ、テーマ、内容の概要をレ ポート用紙1~2枚にまとめて「Interface 投稿 係」までご送付ください、メールでお送りいた だいても結構です(送り先は supportinter @cqpub.co.jpまで). 追って採否をお知らせ いたします。なお、採用分には小社規定の原稿 料をお支払いいたします

#### ▶本誌掲載記事についてのご注意

本誌掲載記事には著作権があり、示されてい る技術には工業所有権が確立されている場合が あります. したがって、個人で利用される場合 以外は, 所有者の許諾が必要です. また, 掲載 された回路,技術,プログラムなどを利用して 生じたトラブルについては、小社ならびに著作 権者は責任を負いかねますので、ご了承ください、

本誌掲載記事を CQ 出版(株)の承諾なしに, 書籍、雑誌、Webといった媒体の形態を問わず、 転載、複写することを禁じます。

#### ▶コピーサービスのご案内

本誌バックナンバーの掲載記事については、 在庫(原則として24か月分)のないものに限り コピーサービスを行っています。コピー体裁は 雑誌見開きの、複写機による白黒コピーです なお、コピーの発送には多少時間がかかる場合 があります。

- •コピー料金(税込み)
  - 1ページにつき100円
- ・発送手数料(判型に関わらず)
- $1 \sim 10$  ページ: 100 円,  $11 \sim 30$  ページ: 200 円,  $31 \sim 50$  ページ: 300 円,  $51 \sim 100$ ページ: 400円, 101ページ以上: 600円
- 送付金額の算出方法 総ページ数×100円+発送手数料
- 入金方法
- 現金書留か郵便小為替による郵送
- 明記事項
- 雑誌名、年月号、記事タイトル、開始ペー ジ, 総ページ数
- ・宛て先

〒 170-8461 東京都豊島区巣鴨 1-14-2 CQ 出版株式会社 コピーサービス係 (TEL: 03-5395-4211, FAX: 03-5395-1642)

#### ▶お問い合わせ先のご案内

- 在庫, バックナンバー, 年間購読送付先変更 に関して 販売部: 03-5395-2141
- ・広告に関して
- 広告部: 03-5395-2133
- ・雑誌本文に関して 編集部: 03-5395-2122

記事内容に関するご質問は,返信用封筒を 同封して編集部宛てに郵送してくださるようお 願いいたします. 筆者に回送してお答えいたし ます

### Interface

©CQ 出版(株) 2003 振替 00100-7-10665 2003年7月号 第29巻 第7号(通巻 2003年7月1日発行(毎月1日発行) 定価は裏表紙に表示してあります 第7号(通巻第313号)

発行人/蒲生良治 編集人/相原 洋

編集/大野典宏 村上真紀 山口光樹 小林由美子 デザイン・DTP/クニメディア株式会社 表紙デザイン/株式会社プランニング・ロケッツ 本文イラスト/神崎真理子 森 祐子 唐沢睦子 広告/澤辺 彰 中元正夫 菅原利江

発行所/CQ出版株式会社 〒170-8461 東京都豊島区巣鴨1-14-2

電話/編集部(03)5395-2122 URL http://www.cqpub.co.jp/interface/ 広告部 (03) 5395 - 2133 インターフェース編集部へのメール

販売部 (03)5395-2141 supportinter@cqpub.co.jp

CQ Publishing Co.,Ltd. / 1 - 14 - 2 Sugamo, Toshima-ku, Tokyo 170-8461, Japan 印刷/クニメディア株式会社 美和印刷株式会社 製本/星野製本株式会社



日本 ABC 協会加盟誌 (新聞雑誌部数公查機構)

ISSN0387-9569

Printed in Japan